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内 容 简 介 


本 书 采用 项 目 式 教学 模式 ,把 ASP . NET 技术 分 为 8 个 项 目 , 具 体内 容 包括 ASP . NET 开发 环境 CHR 
言 基础 ,内置 对 象 . 用 户 输入 的 界面 元 素 SQL Server oa 数据 源 控 件 和 数据 绑 定 控件 АТАХ 
HER Web Service 技术 ;第 9 个 项 目 “ 成 绩 管理 系统 "是 一 个 综合 性 项 目 。 

本 书 在 编排 上 ,注重 理论 与 实践 相 结 合 ,采用 项 日 式 教学 模式 ， 突出 实践 环节 ,充分 体现 “工学 结合 一 
体 化 "教学 思想 。 本 书 将 项 目 分 解 为 若干 任务 ,每 个 任务 由 任务 描述 ,任务 目 的 任务 分 析 、 基 础 知识 ,任务 
实施 任务 小 结 6 个 部 分 组 成 ,全 书 共 设 置 任务 22 个 。 正 文中 设置 了 操作 技巧 .拓展 提高 以 及 知识 链接 等 
特色 模块 , 意 在 提高 学 生 的 学 习 兴趣 ,促进 学 生 的 全 面 发 展 。 全 书 共 设置 项 目 考核 8 个 ,知识 链接 22 个 ， 
小 提示 36 个 ,拓展 提高 15 个 。 每 个 项 目 最 后 设置 了 项 目 小 结 和 项 目 考核 内 容 。 

本 书 所 有 项 目 实例 都 经 过 精心 编写 和 调试 ,保证 能 够 正确 运行 , 书 中 所 有 源 代 码 都 可 以 免费 获得 。 除 
此 而 外 ,还 免费 提供 课程 说 明 教学 参考 ,课件 PPT . 课 后 习题 答案 教学 检测 .资源 扩展 等 教学 资源 。 本 书 
适合 作为 高 职高 专 ,应 用 型 本 科 .成 人 教育 院 校 等 高 校 相 关 课 程 的 教学 用 书 , 同 时 也 可 以 作为 ASP . NET 程 
序 员 的 人 门 学 习 书 籍 以 及 参考 手册 。 


本 书 封面 贴 有 清华 大 学 出 版 社 防伪 标签 ,无 标签 者 不 得 销售 。 
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出 版 说 明 


信息 时 代 早 已 显现 其 诱 人 魅力 ,当前 几乎 每 个 人 随身 都 携 有 多 个 媒体 、 信 息 和 通信 设 
备 ,享受 其 带 来 的 快乐 和 便宜 。 

我 国 高 等 教育 早已 进入 大 众 化 教育 时 代 。 而 且 计算 机 技术 发 展 很 快 ,知识 更 新 速度 也 
在 快速 增长 ,社会 对 计算 机 专业 学 生 的 专业 能 力 要 求 也 在 不 断 翻 新 。 这 就 使 得 我 国 目前 的 
计算 机 教育 面临 严峻 挑战 。 我 们 必须 更 新 教育 观念 一 一 弱化 知识 培养 目的 ,强化 对 学 生 兴 
趣 的 培养 ,加 强 培 养 学 生理 论 学 习 、 快 速 学 习 的 能 力 , 强 调 培养 学 生 的 实践 能 力 动手 能 力 、 
研究 能 力 和 创新 能 力 。 

教育 观念 的 更 新 ,必然 伴随 教材 的 更 新 。 一 流 的 计算 机 人 才 需 要 一 流 的 名 师 指 导 ,而 一 
流 的 名 师 需要 精品 教材 的 辅助 ,而 精品 教材 也 将 有 助 于 催生 更 多 一 流 名 师 。 名 师 们 在 长 期 
的 一 线 教 学 改革 实践 中 ,总结 出 了 一 整套 面向 学 生 的 独特 的 教 法 .经验 ,教学 内 容 等 。 本 套 
丛书 的 目的 就 是 推广 他 们 的 经 验 , 并 促使 广大 教育 工作 者 更 新 教育 观念 。 

在 教育 部 相关 教学 指导 委员 会 专家 的 帮助 和 指导 下 ,在 各 大 学 计算 机 院 系 领导 的 协助 
下 ,清华 大 学 出 版 社 规划 并 出 版 了 本 系列 教材 ,以 满足 计算 机 课程 群 建设 和 课程 教学 的 需 
要 ,并 将 各 重点 大 学 的 优势 专业 学 科 的 教育 优势 充分 发 挥 出 来 。 

本 系列 教材 行文 注重 趣味 性 ,立足 课程 改革 和 教材 创新 , 广 纳 全 国 高 校 计算 机 优秀 一 线 
专业 名 师 参与 ,从 中 精 选 出 佳作 予以 出 版 。 

本 系列 教材 具有 以 下 特点 。 

1. 有 的 放 矢 

针对 计算 机 专业 学 生 并 站 在 计算 机 课程 群 建设 技术 市 场 需求 .创新 人 才 培 养 的 高 度 ， 
规划 相关 课程 群 内 各 门 课程 的 教学 关系 ,以 达到 教学 内 容 互 相 衔接 、 补 充 、 相 互 贯穿 和 相互 
促进 的 目的 。 各 门 课程 功能 定位 明确 ,并 去 掉 课 程 中 相互 重复 的 部 分 ,使 学 生 既 能 够 掌握 这 
些 课程 的 实质 部 分 ,又 能 节约 一 些 课时 ,为 开设 社会 需求 的 新 技术 课程 准备 条 件 。 

2. 内 容 趣味 性 强 

按照 教学 需求 组 织 教学 材料 ,注重 教学 内 容 的 趣味 性 ,在 培养 学 习 观 念 .学 习 兴 趣 的 同 
时 ,注重 创新 教育 ,加强 “创新 思维 " ,创新 能 力 ” 的 培养 .训练 ;强调 实践 ,案例 选 题 注重 实 
际 和 兴趣 度 ,大 部 分 课程 各 模块 的 内 容 分 为 基本 加深 和 拓宽 内 容 3 个 层次 。 

3. 名 师 精 品 多 

广 罗 名 师 参与 ,对 于 名 师 精品 ,予以 重点 扶持 , 教 辅 教 参 、 教 案 、PPT 实验 大 纲 和 实验 
指导 等 配套 齐全 ,资源 丰富 。 同 一 门 课程 ,不 同名 师 分 出 多 个 版 本 ,方便 选用 。 


4. 一 线 教师 亲 力 

专家 咨询 指导 ,一 线 教师 亲 力 ; 内 容 组 织 以 教学 需求 为 线索 ;注重 理论 知识 学 习 , 注 重 学 
习 能 力 培养 ,强调 案例 分 析 , 注 重工 程 技 术 能 力 锻炼 。 

经 济 要 发 展 ,国力 要 增强 ,教育 必须 先行 。 教 育 要 靠 教 师 和 教材 ,因此 建立 一 支 高 水 平 
的 教材 编写 队伍 是 社会 发 展 的 关键 , 特 希望 有 志 于 教材 建设 的 教师 能 够 加 入 到 本 团队 。 通 
过 本 系列 教材 的 辐射 ,培养 一 批 热心 为 读者 奉献 的 编写 教师 团队 。 
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不 知 不 觉 ,从 事 ASP . NET 教学 已 经 有 6 EZ A ,在 教学 中 ,常常 发 现 学 生 在 知识 学 习 
和 实验 中 不 知 所 措 。 学 生 学 习 和 欲望 很 强 , 但 是 教材 大 多 重 理 论 , 轻 实 践 ,很 多 学 生 以 知识 记 
忆 的 方式 学 习 ASP . NET, 记 住 了 很 多 知识 , 却 什么 也 不 会 做 。ASP . NET 是 一 种 编程 技术 ， 
技术 就 要 实战 实 练 ,本 书 以 项 目 式 教学 的 方式 ,讲解 编程 的 过 程 ,重视 实践 ,学 生 跟 着 “任务 
实施 "操作 ,就 可 以 把 任务 完成 ,在 做 项 目 中 学 习 , 在 项 目 实战 中 学 习 , 事 半 功 倍 。 

ASP .NET 是 当前 市 场 上 流行 的 两 大 Web 应 用 程序 开发 技术 之 一 ,不 但 是 最 新 的 Web 
开发 技术 ,也 是 最 容易 和 人 门 的 开发 技术 。ASP . МЕТ HAT ASP 脚本 语言 的 弱点 ,引入 高 级 
语言 C# 语 言 ,使 得 程序 的 安全 性 稳定 性 有 了 很 大 的 提高 ,效率 也 提高 了 很 多 。 总 之 ,今天 
越 来 越 多 的 程序 员 选 择 了 ASP . NET 技术 。 

本 书 自 成 体系 ,包含 ASP . NET 的 语言 基础 C#, 以 及 数据 库 编 程 的 基础 SQL Server 的 使 
用 及 SQL 语言 ,本 书 针对 ASP .NET 新 手 编写 ,阅读 本 书 不 需要 任何 编程 基础 。 本 书 共 分 为 
9 个 项 目 。 

项 目 1 讲解 ASP .NET 开发 环境 Visual Stuido 2010 开发 工具 的 搭建 与 使 用 ,接触 第 一 
个 ASP .NET 的 简单 应 用 程序 。 

项 目 2 讲解 C# 语 言 基础 ,主要 为 没有 学 习 过 C# 语 言 的 读者 准备 。 

项 目 3 讲解 ASP .NET 的 内 置 对 象 ,为 ASP . NET 应 用 程序 使 用 内 置 对 象 

项 目 4 讲解 用 户 输入 的 界面 元 素 , 即 Web 服务 器 控件 .验证 控件 .导航 控件 以 及 母 
版 页 。 

项 目 5 讲解 SQL Server 基础 和 基本 操作 ,ADO. NET 连接 访问 数据 库 的 技术 。 

项 目 6 讲解 数据 源 控件 和 数据 绑 定 控件 ,通过 这 些 控件 ,用 户 可 以 快速 构建 数据 库 
应 用 。 
项 目 7 讲解 ASP .NET 的 热门 技术 
项 目 8 讲解 ASP . NET 的 一 个 高 级 主题 
项 目 9 综合 项 目 一 一 成 绩 管理 系统 。 

本 书 在 编排 上 ,注重 理论 与 实践 相 结合 ,采用 任务 式 教学 模式 ,突出 实践 环节 ,充分 体现 
“工学 结合 一 体 化 "教学 思想 。 本 书 将 项 目 分 解 为 若干 任务 ,每 个 任务 由 任务 描述 任务 目 
的 任务 分 析 .基础 知识 .任务 实施 .任务 小 结 6 个 部 分 组 成 ,全 书 共 设置 任务 22 个 。 正 文 
中 设置 了 操作 技巧 .拓展 提高 以 及 知识 链接 等 特色 模块 , 意 在 提高 学 生 的 学 习 兴 趣 , 促进 学 
生 的 全 面 发 展 。 全 书 共 设置 项 目 考核 8 个 ,知识 链接 22 个 ,小 提示 36 个 ,拓展 提高 15 个 。 
每 个 项 目 最 后 设置 了 项 目 小 结 和 项 目 考核 内 容 。 配 备 完整 的 教学 资源 ,包括 课程 说 明 教学 
参考 ,课件 PPT \ 课 后 习题 答案 教学 检测 .资源 扩展 等 教学 资源 ,方便 教师 教学 和 学 生 自 学 。 

本 书 既 可 以 作为 高 职高 专 .应 用 型 本 科 成 人 教学 院 校 .各 类 计算 机 培训 学 校 相 关 课 程 
的 教学 用 书 ,也 可 作为 ASP . NET 程序 员 学 习 的 入 门 教程 或 参考 资料 。 

本 书 由 安阳 工学 院 的 王 庆 喜 . 储 泽 楠 . 齐 万 华 КЇН , 赵 浩 婕 、 孙 高 飞 6 位 老师 共同 编写 ， 

Ш. 


AJAX, 这 是 Web 应 用 程序 的 趋势 。 
Web Service ,本 项 目 技术 含量 较 高 。 


由 王 庆 喜 老 师 统 一 定稿 。 在 编写 过 程 中 得 到 了 许多 专家 和 老师 的 帮助 和 支持 ,在 此 表示 
感谢 。 

我 们 以 科学 、 严 并 的 态度 编写 本 书 ,但 是 计算 机 技术 发 展 迅速 ,作者 水 平 所 限 , 书 中 错误 
和 玻 漏 之 处 在 所 难免 , 敬 请 专家 和 广大 读者 批评 指正 。 
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项 目 1 ASP .NET 开发 环境 
一 、 引 言 


ASP .NET 作为 Microsoft 公司 推出 的 . NET 技术 的 网 络 应 用 平台 ,已 经 被 广大 的 编程 人 
员 采 用 ,成 为 目前 基于 Web 应 用 程序 开发 中 最 流行 和 最 前 沿 的 技术 。 本 章 主要 介绍 ASP . 
NET 和 Visual Studio 2010 集成 开发 工具 ,并 通过 简单 的 入门 级 实例 ,使 读者 对 ASP . NET 有 
一 个 初步 认识 。 

工 欲 善 其 事 , 必 先 利 其 器 。 学 习 ASP . NET 必须 熟练 掌握 Visual Studio 工具 的 使 用 ,本 
书 采 用 Visual Studio 2010 版 本 ( 简称 VS 2010) 。 在 比较 新 的 版 本 中 ,Visual Studio 在 功能 上 
和 开发 使 用 上 几乎 没有 差别 。 


二 、 项 目 要 点 


(1) 了 解 Visual Studio 2010 的 安装 。 
(2) 掌握 Visual Studio 2010 窗口 的 基本 操作 。 
(3) 了 解 ASP .NET Web 应 用 程序 的 一 般 开 发 过 程 。 


cR 
任务 1-1 安装 Visual Stuido 2010 


【任务 描述 】 

小 王 本 来 是 开发 ASP 程序 的 ,最 近 听 说 ASP . NET 越 来 越 火 ,使 用 的 人 越 来 越 多 ,因此 
也 想 学 习 , 好 提升 自己 的 薪资 待遇 。 小 王 非常 清楚 ,要 想 学 习 编 程 技术 ,开发 工具 是 必 不 可 
少 的 ,他 想 使 用 Visual Stuido 2010 来 开发 应 用 程序 ,所 以 安装 Visual Stuido 2010 是 目前 必须 
做 的 事情 了 。 

【任务 目的 】 

(1) 理解 ASP .NET 的 相关 概念 。 

(2) 掌握 Visual Stuido 2010 的 安装 过 程 。 


【任务 分 析 】 

一 个 好 的 开发 工具 可 以 使 开发 工作 事半功倍 ,而 使 用 . NET 平台 进行 应 用 程序 开发 的 
最 好 工具 葛 过 于 Visual Studio。 本 书 采 用 Visual Studio 2010 集成 开发 环境 。 

Visual Stuido 2010 的 安装 比较 简单 ,与 Windows 平台 下 很 多 软件 一 样 ,基本 上 是 一 路 单 
击 * 下 一 步 "按钮 即 可 完成 。 


【基础 知识 

1. ASP .NET 

ASP .NET 是 . NET Framework 的 一 部 分 ,是 微软 公司 的 一 项 技术 ,是 一 种 使 舱 入 网 页 中 
的 脚本 可 由 因特网 服务 器 执行 的 服务 器 端 脚本 技术 , 它 可 以 在 通过 HTTP 请 求 文档 时 在 
Web 服务 器 上 动态 创建 它们 。 

知识 链接 : 网 站 应 用 程序 开发 技术 主要 有 ASP. NET JSP ASP PHP 等 。 目 前 市 场 占有 
份额 较 大 的 是 ASP.NET 和 JSP 技术 。 

2. .NET Framework 体系 结构 

.NET Framework 包含 一 个 执行 平台 ,其 形式 是 虚拟 机 。 МЕТ Framework 还 包含 几 种 可 
以 为 这 个 虚拟 机 创建 程序 的 编程 语言 ,以 及 丰富 的 类 库 ,为 这 些 语言 创建 丰富 的 内 置 功能 。 

.NET Framework 覆盖 了 在 操作 系统 上 开发 软件 的 所 有 方面 ,为 集成 Microsoft 或 任意 平 
台 上 的 显示 技术 组件 技 术 和 数据 技术 提供 了 最 大 的 可 能 。 创 建 出 来 的 整个 体系 可 以 使 
Internet 应 用 程序 的 开发 就 像 桌面 应 用 程序 的 开发 一 样 简单 。 

.NET Framework 实际 上 “封装 ”了 操作 系统 ,把 用 . NET 开发 的 软件 与 大 多 数 操作 系统 
特性 隔离 开 来 ,例如 文件 处 理 和 内 存 分 配 。 这 样 ,为 . NET 开发 的 软件 就 可 以 移植 到 许多 不 
同 的 硬件 和 操作 系统 上 。 

该 架构 的 底层 是 内 存 管理 和 组 件 加 载 层 ,最 高 层 提 供 了 显示 用 户 和 程序 界面 的 多 种 方 
式 。 在 这 两 者 之 间 的 层 仅 提 供 开 发 人 员 需 要 的 所 有 系统 级 功能 。 

3. Visual Studio 2010 

Visual Studio 2010 H|] Microsoft Visual Studio 2010 ,是 微软 公司 推出 的 开发 环境 。 是 目前 
最 流行 的 Windows 平台 应 用 程序 开发 环境 。Visual Studio 2010 版 本 于 2010 年 4 月 12 日 上 
市 ,其 集成 开发 环境 (IDE) 的 界面 被 重新 设计 和 组 织 , 变 得 更 加 简单 明了 。Visual Studio 
2010 同时 带 来 了 . NET Framework 4.0、Microsoft Visual Studio 2010 СТР ( Community 
Technology Preview, CTP) ,并 且 支 持 开 发 面向 Windows 7 的 应 用 程序 。 除 了 Microsoft SQL 
Server, 它 还 支持 IBM DB2 和 Oracle 数据 库 。 

(1) Visual Studio 的 9 个 新 功能 。Visual Studio 2010 是 一 个 经 典 的 版 本 ,相当 于 当年 的 
6.0 版 。 它 可 以 自 定义 开始 页 ,还 包括 以 下 新 功能 : 

@ CH 4.0 中 的 动态 类 型 和 动态 编程 ; 

@ 多 显示 器 支持 ; 

(3) 使 用 Visual Studio 2010 的 特性 支持 TDD; 

Ф 支持 Office; 

© Quick Search 特性 ; 

© C++ Ox 新 特性 ; 

@ IDE 增强 ; 

使 用 Visual C ++ 2010 创建 Ribbon 界面 ; 

© 新 增 基 于 . NET 平台 的 语言 F#。 

(2) 六 大 创新 。 根 据 微软 发 布 的 一 份 官方 文档 宣称 , Visual Studio 2010 ЖП. NET 
Framework 4.0 在 以 下 6 个 方面 有 所 创新 。 

O 民主 化 的 应 用 程序 生命 周期 管理 。 在 一 个 组 织 中 ,应 用 程序 生命 周期 管理 (ALM ) 将 
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涉及 多 个 角色 。 但 是 在 传统 意义 上 ,这 一 过 程 中 的 每 个 角色 并 不 是 完全 平等 的 。Visual 
pue Team System 2010 坚持 打造 一 个 功能 平等 .共同 分 担 的 平台 以 用 于 组 织 内 的 应 用 程序 

命 周 期 管理 过 程 。 

@ 顺应 新 的 技术 潮流 。 每 年 ,业界 内 的 新 技术 和 新 趋势 层出不穷 。 通 过 Visual Studio 
2010 ,微软 公司 为 开发 者 提供 合适 的 工具 和 框架 ,以 支持 软件 开发 中 最 新 的 架构 ,开发 和 
部 署 。 

@ 让 开发 商 惊喜 。 从 Visual Studio 的 第 一 个 版 本 开始 ,微软 公司 就 将 提高 开发 人 员 的 
工作 效率 和 灵活 性 作为 自己 的 目标 。Visual Studio 2010 将 继续 关注 并 且 显 著 地 改进 开发 者 
最 核心 的 开发 体验 。 

@ 下 一 代 平 台 浪潮 的 弄潮儿 。 微 软 公 司 热 忠 于 开发 市 场 领先 的 操作 系统 .工具 软件 和 
服务 器 平台 ,为 客户 创造 更 高 的 价值 。 使 用 Visual Studio 2010 ,可 以 在 新 一 代 的 应 用 平台 上 
为 客户 创造 令 人 惊奇 的 解决 方案 。 

© 跨 部 门 应 用 。 客 户 将 在 不 同 规模 的 组 织 内 创建 应 用 ,跨度 从 单个 部 门 到 整个 企业 。 
Visual Studio 2010 确保 在 这 么 宽泛 的 范围 内 的 应 用 开发 都 得 到 支持 。 

© 高 效 开 发 环境 。Microsoft Visual Studio 2010 采用 拖 电 方式 完成 软件 的 开发 ,简单 的 
操作 便 可 以 实现 一 个 界面 的 生成 ,所 拖 电 的 界面 ,也 可 以 用 相应 的 代码 来 实现 功能 。Microsoft 
Visual Studio 2010 支持 C# C ++ „Visual Basic ,可 以 快速 实现 相应 的 功能 。 

小 提示 : 本 书 讲 解 的 知识 和 技术 属于 基础 的 内 容 , 对 Visual Studio 开发 工具 的 版 本 要 求 
不 严格 ,使 用 Visual Studio 2008 也 是 可 以 的 。 


【任务 实施 】 
第 1 步 А Visual Stuido 2010 安装 光盘 到 光驱 ,如 图 1-1 所 示 。 
_ 
QQ- wan, k=: "Tel aem и: 


Dg 4 硬盘 (4) 
dé FE ®юшас O O OO ®ёшао OOOO 
am > u€— | 
| = > T EP oun. к=з 
| 本 地 磁盘 (E) 本 地 磁盘 (ғ) 
as і «21е т mic 
Buz 3 


有 可 移动 存储 的 设备 (1) | 


= BD-ROM 363988 (G) 
国 жм X16-60997VS2010UltimTrialCHS 
фа 0 = ЕПН. #t 2.50 GB. 
< sb) | 
S BL | 
(qv use 视频 没 备 | 
LL 
BD-ROM 驱动 器 (G;) X16-60997V5201... 可 用 空间 : 0 =F 文件 系统 : UDF 
| CD 驱动 器 总 大 小 : 250 GB. 
—À —— “zb 


图 1-1 光驱 中 的 Visual Stuido 2010 
小 提示 : 本 书 采 用 虚拟 光驱 (Daemon Tools Lite) 安装 ,读者 可 以 自行 决定 安装 方式 。 
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第 2 步 ”双击 打 开光 驱 ,找到 Setup 文件 ,双击 Setup 图 标 ( 文 件 ) , 即 可 打开 安装 程序 窗 
HO ,如 图 1-2 所 示 。 
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rosoft Visual Studio 2010 
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图 1.2 ”安装 程序 窗口 


第 3 步 单 击 对 话 框 中 的 “安装 Microsoft Visual Studio 2010" 按 钮 ,打开 安装 前 的 准 
文件 界面 ,如 图 1-3 所 示 。 
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图 1-3 安装 界面 


第 4 步 ， 单 击 * 下 一 步 " 按 钮 ,出 现 * 协 议 与 安装 产品 密 钥 " 对 话 框 , 如 图 1-4 所 示 。 
小 提示 : 产品 密 钥 。 根 据 采 用 的 Visual Stuido 2010 安装 盘 不 同 , 有 的 安装 盘 会 让 用 户 
уе, 
第 5 步 ， 选 中 “我 已 经 阅读 并 接受 许可 条 款 " 单 选 框 , 单 击 “下 一 步 ? 按 钮 ,打开 < 安装 程 
E E 
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图 14 安装 程序 -起 始 页 
序 -选项 页 "对话 框 ,如 图 1-5 所 示 。 
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图 1-5 安装 程序 -选项 页 


第 6 步 ” 根据 实际 情况 输入 “产品 安装 路 径 " 后 , 单 击 “ 安 装 ”按钮 ,开始 安装 ,安装 过 程 
如 图 1-6 所 示 。 
第 7 步 ” 安 装 完成 后 ,系统 自动 打开 “安装 程序 -完成 页 ” ,如 图 1-7 所 示 。 单 击 “ 安 装 程 
.5. 
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正在 安装 组 件 : 
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图 1.6 ”安装 程序 -安装 页 
序 - 完 成 页 "对 话 框 上 的 “完成 "按钮 ,安装 完成 。 
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成 功 


Visual Studio 2010 安装 完成 。 
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М gemas. 
RO» 建议 您 选择 户 用 Microsoft Update 服务 ， 以 确保 收 到 此 产品 和 其 他 Microsoft 产品 的 所 有 可用 更 新 。 
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АЙТА: Аяу Visul Studio 集 所 的 扩展 ， 以 全 进一步 提高 开 发 效率 。 


' 
Dict m Help Library 管理 器 ， 它 将 指导 您 完成 配置 Visual Studio 本 地 帮助 的 全 过 程 。 详 细 信息 . . . 


图 1-7 安装 程序 -完成 页 


【任务 小 结 】 
本 任务 比较 简单 ,是 在 Windows 7 下 的 软件 安装 ,基本 上 是 一 路 单 击 “ 下 一 步 "按钮 即 
"p. 在 安装 过 程 中 过 到 问题 ,可 以 上 网 查找 解决 办 法 。 


任务 1-2 使 用 Visual Stuido 2010 开发 ASP .NET 入 门 应 用 程序 


【任务 描述 】 

小 王 在 安装 了 Visual Stuido 开发 工具 后 , 想 做 一 个 简单 的 例子 ,也 就 是 一 个 入 门 的 应 用 
程序 。 编 程 最 简单 的 例子 就 是 “Hello World" ,但 小 王 以 前 开发 过 ASP 程序 ,有 些 基 础 ,因此 
他 要 做 一 个 比 “Hello World" 难 一 点 的 程序 ,要 有 一 定 交互 功能 的 应 用 程序 。 


【任务 目的 】 

熟悉 Visual Stuido 2010 的 基本 操作 。 
掌握 ASP .NET 应 用 程序 的 开发 流程 。 
了 解 ASP .NET 开发 的 相关 知识 。 


【任务 分 析 】 

本 任务 展示 使 用 Visual Stuido 2010 开发 ASP . NET 应 用 程序 的 过 程 ,让 读者 对 ASP . 
NET 开发 有 一 个 直观 的 了 解 。 本 任务 涉及 知识 较 少 ,只 有 TextBox , Button 和 Label 控件 ,以 
及 事件 驱动 开发 的 知识 ,对 于 这 些 知识 在 后 续 的 项 目 中 ,还 会 详细 讲解 。 

【基础 知识 

1. Visual Stuido 2010 的 IDE 界面 

(1) 客户 设计 区 : 用 Visual Stuido 2010 打开 网 页 后 ,其 中 最 大 的 区 域 就 是 客户 设计 区 ， 
它 是 用 户 用 来 设计 页 面 的 主要 环境 。 

可 以 通过 单 击 左下 角 的 “设计 ”和 * 源 "切换 设计 页 面 和 HTML 源码 。 

(2) 工具 箱 : Visual Stuido 2010 给 用 户 提 供 了 很 多 控件 ,包括 标准 控件 .数据 控件 .验证 
控件 .导航 控件 和 Ajax 控件 等 。 

(3) 解决 方案 资源 管理 器 : 解决 方案 资源 管理 器 的 功能 是 管理 一 个 应 用 程序 中 所 有 的 
属性 记忆 组 成 该 应 用 程序 的 所 有 文件 。 

(4) 属性 : 选中 页 面 中 的 控件 , 则 在 属性 框 中 显示 出 选中 控件 的 属性 ,并 可 以 在 属性 框 
中 对 所 选 控件 的 属性 进行 修改 。 

2. 菜单 

(1)“ 文 件 " 菜 单 。 在 IDE 的 上 方 是 IDE 的 功能 菜单 “文件 "菜单 包括 3 个 主要 的 功 
能 菜单 项 : 

(“新 建 "”: 用 来 创建 新 的 项 目 或 网 站 的 菜单 项 ,“ 新 建 "菜单 项 下 有 “项 目 ”“ 网 站 " 菜 
单项 ,其 中 “项 目 " 是 创建 基于 Windows 的 应 用 程序 ,“ 网 站 ”是 创建 基于 Web 的 网 站 。 

D “HF”: 打开 已 经 创建 的 项 目 或 网 站 。 

®© “推出”; 推出 Visual Stuido 2010, 

(2)“ 视 图 "菜单 。“ 视 图 "十 分 重要 , 它 集 合 了 IDE 提供 的 所 有 窗口 。 

QD“ 解 决 方案 资源 管理 器 ”: 如 果 误 操作 把 解决 方案 浏览 器 关闭 了 ,可 以 在 这 里 通过 选 
择 “ 解 决 方案 资源 管理 器 "命令 重新 打开 该 面板 。 关 闭 该 面板 只 需 单 击 面板 右上 方 的 “ 关 
闭 ”" 按 钮 即 可 。 

@“ 服 务 器 资源 浏览 器 ” : 如 果 误 操作 把 “服务 器 资源 浏览 器 "面板 关闭 了 ,可 以 在 这 里 
通过 选择 “服务 器 资源 浏览 器 ”命令 重新 打开 该 面板 。 


equ 


图 “错误 清单 " :“ 错 误 清 单 " 面 板 集中 显示 所 有 在 编译 过 程 中 遇 到 的 错误 ,并 指出 错误 
的 位 置 。 选 中 “错误 清单 ” , 则 打开 “错误 清单 "面板 。 

@ “输入 窗口 ”: 程序 输出 的 结果 显示 窗口 。 

© “ҖЕ”. 如 果 在 Visual Stuido 2010 中 没有 属性 框 , 可 以 在 这 里 通过 选择 “属性 ”命令 
打开 “属性 "面板 。 

© “ТАЖ”: 如 果 在 Visual Stuido 2010 中 没有 “工具 箱 ” 面板 ,可 以 在 这 里 通过 选择 
“工具 箱 ” 命 令 打 开 “ 工 具 箱 ”面板 。 

知识 链接 : 解决 方案 资源 管理 器 .工具 箱 、 属 性 窗口 是 在 开发 中 使 用 最 多 的 几 个 窗口 ， 
客户 设计 区 是 开发 人 员 设 计 界 面 的 区 域 。 

3. ASP .NET Web 应 用 程序 开发 过 程 

(1) 新 建 一 个 网 站 。 

(2) 添加 一 个 Web 窗 体 。 

(3) 为 Web 窗 体 添 加 控件 。 

(4) 设置 页 面 控 件 的 属性 。 

(5) 编写 代码 。 

(6) 测试 与 运行 程序 。 

4. 事件 驱动 编程 

传统 程序 一 般 是 按照 从 上 至 下 、 从 前 至 后 的 顺序 执行 的 ,事件 驱动 编程 模式 改变 了 传统 
的 编程 模式 。 
事件 是 按照 一 个 对 象 发 送 消息 通知 另 一 个 对 象 操作 的 机 制 来 执行 的 ,他 可 以 用 于 对 象 
间 的 同步 和 信息 传递 。Windows 操作 系统 就 是 由 事件 驱动 的 , 它 不 依 顺序 方式 执行 , 4 
Windows 启动 后 ,就 等 待 事件 的 发 生 ,例如 用 户 双击 “我 的 电脑 ”图 标 或 者 单 击 “ 开 始 " 按 钮 
等 ,只 有 发 生 了 事件 , Windows 才 会 执行 相应 的 动作 处 理事 件 。 

在 ASP .NET 中 ,页 面 显示 在 浏览 器 中 ,等 待 用 户 交 互 , 当 用 户 单 击 按钮 时 就 发 生 一 个 事 
件 。 程 序 会 执行 相应 的 代码 来 响应 事件 。 在 代码 执行 结束 后 ,页面 返回 ,继续 等 待 下 一 个 事件 。 

ASP .NET 的 事件 分 为 3 类 。 

(1) HTML 事件 。 这 些 事件 可 以 在 网 页 上 发 生 ,并 由 浏览 器 在 客户 端 处 理 , 如 在 客户 端 
JavaScript 中 运行 弹出 框 等 。 

(2) 自动 触发 事件 。ASP . NET 页 面 生成 时 ,会 自动 触发 一 些 事件 ,它们 不 需要 干涉 ,在 
用 户 看 到 页 面 之 前 执行 ,使 用 这 些 事件 可 以 初始 化 页 面 。 

(3) 用 户 交互 事件 。ASP . NET 的 事件 处 理 采 用 委托 机 制 ,如 按钮 的 Click 事件 ,编程 
时 在 设计 上 双击 按钮 ,程序 会 自动 添加 事件 的 相应 方法 ,代码 如 下 。 

Protected void Buttonl Click (фјесе sender, EventArgs e) 

{ 


} 

一 般 情 况 下 ,事件 的 响应 方法 中 包含 两 个 参数 ,其 中 一 个 参数 代表 引发 事件 的 对 象 
sender, 由 于 引发 事件 的 对 象 是 不 可 预知 的 ,因此 将 其 声明 为 Object 类 型 ,使 用 于 所 有 对 象 ; 
另 一 个 参数 代表 引发 事件 的 具体 信息 ,在 各 种 类 型 的 事件 中 可 能 不 同 ,因此 采用 了 

RE 


EventArgs 类 型 ,用 于 传递 事件 的 细节 。 

知识 链接 : 事件 驱动 模型 三 大 要 素 。 事 件 源 : 能 够 接收 外 部 事件 的 源 体 ; 侦 听 器 : 能 够 
接收 事件 源 通知 的 对 象 ; 事 件 处 理 程序 : 用 于 处 理事 件 的 对 象 。 在 页 面 第 一 次 运行 时 ,ASP 
.NET 创建 页 面 和 控件 对 象 ,接着 执行 初始 化 代码 ,然后 页 面 被 呈现 为 HTML 并 返回 到 客户 
端 ,页 面 对 象 在 服务 器 内 存 中 被 释放 掉 ; 用 户 在 某 点 触发 某 个 事件 时 ,例如 单 击 某 个 按钮 ,页 
面 所 有 的 表单 数据 被 提交 ;ASP . МЕТ 截获 这 些 返 回 的 页 面 并 重建 页 面 对 象 ,准确 还 原 对 象 
在 页 面 被 发 送 到 客户 端 时 的 最 后 状态 ;ASP . NET 检查 是 什么 操作 触发 了 事件 ,引发 相应 的 
事件 ;修改 后 的 页 面 转 化 成 HTML 并 返回 到 客户 端 。 


【任务 实施 】 

小 提示 : 本 任务 的 目的 是 熟悉 Visual Stuido 2010 的 使 用 ,简单 了 解 ASP . NET 开发 , 实 
施 过 程 中 不 要 求 读者 对 使 用 到 的 知识 和 技术 都 十 分 熟悉 和 掌握 ,因为 这 些 知识 和 技术 在 以 
后 的 项 目 中 会 深入 讲解 。 但 是 对 于 Visual Stuido 2010 的 操作 必须 尽快 熟悉 ,比如 创建 网 站 、 
添加 Web 窗 体 、 拖 放 控 件 .设置 控件 属性 等 。 

第 1 步 启动 Visual Stuido 2010。 选 择 “ 开 始 ”" 1“ 所 有 程序 ”| Microsoft Visual Studio 
2010 | Microsoft Visual Studio 2010 菜单 命令 ,打开 Visual Studio 2010。 如 图 1-8 所 示 。 


© Microsoft Visual Studio 正在 jp 载 用 户 设置 。 这 可 能 需要 几 分 钟 的 时 
iB. 


图 1-8 启动 Visual Stuido 2010 


第 2 步 ” 启 动 完成 后 ,系统 自动 打开 “选择 默认 环境 设置 "对 话 框 ,如 图 1-9 所 示 。 


O Visual studio 2010 旗 舰 版 


首次 开始 使 用 该 应 用 程序 之 前 ， 需 要 指定 您 从 事 最 多 的 开发 活动 类 型 ,如 Visual Basic 或 Visual 
C#。 此 信息 用 于 将 预定 义 的 设置 集合 应 用 于 针对 您 的 开发 活动 而 设计 的 开发 环境 . 


您 可 以 随时 选择 使 用 不 同 的 设置 集合 。 方 法 是 从 “工具 ” 药 单 中 选择 “导入 和 导出 设置 ” ， 然后 先 


对 环境 进行 后 定义， 可 将 代码 编辑 器 的 屏幕 空间 最 大 
开发 设置 化 ,并 改善 特定 于 C# 的 命令 的 可 见 性 。 通 过 为 便于 
Visual F# 开发 设置 学 习 和 使 用 而 设计 的 键盘 快捷 键 提 高 生产 力 . 
Web 开发 
Web 开发 ( 仅 代码 ) 
SATARE 
项 目 管理 设置 


退出 Visual Studio00) 


图 1-9 设置 默认 环境 


第 3 步 选择 默认 环境 设置 。 选 中 * Visual C# 环 境 设置 "选项, 单 击 “ 启 动 Visual 
Studio" 按钮 ,打开 Visual Stuido 2010 主 界面 ,如 图 1-10 所 示 。 这 个 步骤 只 有 在 安装 后 第 一 
次 启动 时 才 需 要 。 
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图 1-10 Visual Stuido 2010 主 界面 


第 4 步 ” 选 择 “ 文 件 "1“ 新 建 "1“ 网 站 ”菜单 命令 ,打开 “新 建 网 站 ”对 话 框 ,如 图 1-11 所 
示 , 单 击 其 中 的 “浏览 "按钮 ,选中 或 创建 一 个 文件 夹 


? P3 
最 的 模板 [NET Framework 4 > Ја [Rt Вн E> а]! 
Pesto x | 
э ASPJNET 网 站 Visual ce NI Vind Ot 
Visual Basic - zm 
d [ ATE Visual ce 
e 
Ф ASP.NET Dynamic Data 实体 网 站 Visual ce 
& ASP.NET Dynamic Data Linq to SQL 网 站 Visual Се 
EE wees Visual cs 
= ASP.NET Reports 网 站 Visual C 
E ASPJNET Crystal Reports 网 站 Visual ce 
Web EU): 文件 系统 m| DAnetworlàchap1-1 т | йв. 
ити 


图 1-11 新 建 网 站 
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第 5 步 ” 如 果 输 入 的 文件 夹 不 存在 , 则 会 弹出 “创建 文件 夹 " 提示 对 话 框 ,如 图 1-12 所 示 。 


Microsoft Visual Studio 


eo жЕ *D3networkichap1-1" ЖЕНЕ. SAARA? 


av |[ аф 


图 1-12 文件 夹 不 存在 提示 


第 6 步 ” 在 “解决 方案 资源 管理 器 "中 ,选中 网 站 后 右 击 ,从 弹出 的 快捷 菜单 中 选择 “ 添 
加 ”命令 ,打开 “添加 新 项 "对话 框 ,如 图 1-13 所 示 。 


?| 
теша a) CE, 
T wema шшс, 3 ME Visual Cs 
ER Web алела 
7 = Visual се 
Р 
a| web meme Visual Се 
а. ADO.NET EntityObject 生成 路 Visual Cf 
| ^ooncr stam Visual cz 
dh ApoNEr emt Visual ce 
2 
P сунаж Visual cz 
фу panic osa ria Visual Са 
(2) HTML 页 Visual cx 
(si JScript 文件 Visual Сё 
B LINQ to SQL ё Visual Сё 
(SM siverigh Lo Script Xt Visual Cs 
Default.aspx 将 代码 放 在 单独 的 文件 中 (P) 
анато 


图 1-13 添加 网 页 


第 7 步 ” 在 “添加 新 项 "对话 框 中 ,选中 “Web 窗 体 " 后 , 单 击 “ 添 加 ”按钮 , 则 添加 网 页 
成 功 ,如 图 1-14 所 示 。 

第 8 步 Mif Visual Stuido 2010 下 方 的 “设计 ”按钮 ,切换 “源码 界面 "到 “设计 界面 ”， 
如 图 1-15 所 示 。 

小 提示 : 对 于 初学 者 ,主要 使 用 “设计 界面 " ,对 于 经 验 丰富 的 编程 者 ,可 能 更 喜欢 使 用 
“源码 界面 ”。 

第 9 步 ” 从 工具 箱 中 拖 入 一 个 TextBox 控件 一 个 Button 控件 和 一 个 Label 控件 到 设计 
界面 中 ,如 图 1-16 所 示 。 

第 10 步 ” 修改 TextBox 属性 ,如 图 1-17 所 示 。 

第 11 步 修改 Button 属性 ,如 图 1-18 所 示 。 

第 12 步 ” 修改 Label 属性 ,如 图 1-19 所 示 。 
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图 1-14 网 页 编辑 源 代 码 界面 


em chap1-1 - Microsoft Visual Studio (E988) = 
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图 1-15 网 页 编辑 设计 界面 


оо chap1-1 - Microsoft Visual Studio( EER) ç [= | = le) 


ваць 
| 


same | 回 源 | [ [Боду оттоп «aspiButtonfButtoni» 


图 1-16 设计 后 界面 
E РЖ 


[38 -ax ze zex 529 TAX 


tbxusername System. Web.ULWebControls.Tex ~ Buttonl System.Web.ULWebControlsButton ~ Iblmsg System.Web.ULWebControlslabel = 
(Expressions) ^ (Expressions) ^ (Expressions) 
aD) tbxusername ар) Button1 00) Iblmsg 
AccessKey AccessKey AccessKey 
AutoCompleteType None BackColor AssociatedControlIC 
AutopostBack False BorderColor BackColor 
BackColor BorderStyle NotSet BorderColor 
BorderColor BorderWidth BorderStyle NotSet 
BorderStyle NotSet CausesValidation True BorderWidth 
BorderWidth ClientiDMode Inherit ClieniDMode Inherit 
CausesValidation False F CommandArgument CssClass 
ClieiDMode Inherit CommandName I Enabled True 
Columns o Cssclass EnableTheming Тһе 
CssClass Enabled True EnableViewState- True 
Enabled True EnableTheming — True b Font 
EnableTheming — True EnableViewState — True ForeColor 
EnableViewStete — True P Font Height 

b Font ForeColor SkinID 
ForeColor Height Tabindex 0 
Height OnClientClick Text 
MexLength o PostBackUr ToolTip 
ReadOnly False SkinID ViewStateMode Inherit 
Rows 0 TabIndex 0 Visible True 
SkinlD Text 提交 Width 
Tabindex 0 E тоор E 

aD) Tet 

此 控件 的 编程 名 称 . 将 在 按钮 上 显示 的 文本 . 


图 1-17 Label 属性 设置 窗口 图 1-18 Button 属性 设置 窗口 图 1-19 TextBox 属性 设置 窗口 


第 13 步 ” 双 击 设 计 界 面 中 的 Button 按钮 ,进入 逻辑 代码 编辑 界面 ,直接 跳 转 到 Button 
的 Click 事件 中 ,如 图 1-20 所 示 。 


eo chap1-1 - Microsoft Visual Studio (828) lele] = J 


日 using 

using System. Collections. Generic; 
using System. Linq; 

using System. Wel 

using System. Web. UI 

using System. Web. UI. VebControls; 


Ejpublic partial class Default : System. Web. UI. Page 


Ej protected void Page Load(object sender, EventArgs e) 
t 


1 
Ej protected void Buttonl Click(object sender, Eventárgs e) 


图 1-20 页面 事件 


第 14 步 ”添加 Button 的 Click 事件 代码 ,代码 如 图 1-21 所 示 。 
第 15 步 ” 启 动 调试 。 选 择 “ 调 试 "1“ 启 动 调试 "菜单 命令 ,或 单 击 工具 栏 中 的 “启动 调 


„13. 


oo chap1-1 - Microsoft Visual Studio(882822) 7 БЕЗ 


\ 
t 


1 
| protected void Buttonl Click(object sender, Eventárgs e) 
t 


string username = this. tbxusername. Text; 
| this. lblnsg. Text = “ASP. NET 世 界 ， 欢迎“tusername+" 到 来 !“; 
} 


图 1-21 事件 内 代码 


试 " 图 标 ,系统 开始 调试 网 页 ,第 一 次 调试 时 ,会 弹出 “未 启动 调试 "提示 对 话 框 ,如 图 1-22 
所 示 。 


由 于 未 在 Web.config 文件 中 启用 泗 坛 ,因此 无 法 在 调试 模式 下 运行 该 页 ， 您 项 望 做 什么 ? 


© 修改 Web.config ЖННД (М). 
A 在 生产 环境 中 部 署 网 站 之 前 ,应 在 Web.config KERRAN. 


© 不 进行 调试 直接 运行 (R)。( 等 同 于 Ctrl+F5) 


图 1-22 调试 提示 框 
第 16 步 单 击 “ 确 定 " 按 钮 ,打开 网 页 ,如 图 1-23 所 示 。 


Еа > 文件 B8 бш IA 帮助 # - D x 


£ || | ft || @ | http//localhost:54264/chap BI f |ҹ || 0. sitis Q. | 
bta- Elem Jamie Amo > Birr- QAR- ш» 


dex | 


eue Фте m @ S Q Qi 


图 1-23 页 面 打 开 效 果 


dH. 


知识 链接 : 单 击 “ 确 定 "按钮 后 ,系统 为 网 站 添加 了 Web. xml 文件 ,这 是 一 个 XML 的 文 
件 , 用 来 配置 网 站 。 

第 17 步 ， 再 输入 框 中 输入 比尔 盖 蒋 后 , 单 击 * 提 交 " 按钮 ,页面 刷新 后 ,内 容 改变 ,如 
图 1-24 所 示 。 


ES m > 文件 查看 бш IB 帮助 | — D x 
e € @ ft © htp//ocalhost5a262/chap BE $ v || BJ. sutis Q. | 


фбе- гв Dmie бавно > ПУЕ QAR- BE» 


ERER [382] AsP. NET 世界 ， 欢 迎 比尔 羔 获 到 来 ! 


ese фк P @ © Q Q1 


图 1-24 页 面 操作 效果 


【任务 小 结 】 

本 任务 使 用 Visual Stuido 2010 开发 一 个 小 程序 ,程序 中 只 有 一 个 网 页 ,网 页 中 有 一 个 
TextBox 控件 一 个 Button 控件 和 一 个 Label 控件 ,其 中 TextBox 控件 是 让 用 户 录入 数据 的 录 
入 框 ,Button 控件 是 触发 提交 数据 事件 的 按钮 ,Label 控件 显示 提交 数据 后 的 返回 信息 。 


【拓展 提高 】 

1. C/S 和 B/S 结构 体系 

目前 在 程序 开发 领域 中 , 主要 有 两 大 编程 体系 : 一 个 是 基于 操作 系统 平台 的 C/S 结构 ， 
另 一 个 是 基于 浏览 器 的 B/S 结构 。 

(1) C/S 架构 体系 。C/S 即 客户 机 /服务 器 ,通常 程序 将 开发 完成 的 软件 安装 在 某 计算 
机 (客户 机 ) 中 ,将 数据 库 安 装 在 专用 的 服务 器 ( 数据库 服务 器 ) 中 ,这 样 可 以 利用 两 端 硬件 
资源 ,将 任务 合理 地 分 配 到 客户 端 和 服务 器 端 ,降低 了 系统 的 通信 开销 。 这 种 架构 要 求 客户 
机 中 必须 安装 客户 端 程序 ,否则 无 法 工作 。 

(2) B/S 架构 。B/S 即 浏览 器 /服务 器 , 它 由 客户 机 应 用 服务 器 和 数据 库 服务 器 3 部 
分 组 成 。B/S 架构 中 ,不 需要 在 客户 机 上 安装 专门 的 客户 机 软件 ,用户 在 使 用 程序 时 仅 需要 
通过 安装 在 客户 机 上 的 浏览 器 访问 指定 的 Web 服务 器 即 可 。 目 前 ,B/S 架构 已 经 成 为 应 用 
程序 的 主流 选择 。 

小 提示 : 目前 主流 的 体系 结构 是 B/S, 并 且 ASP .NET 技术 也 是 B/S 结构 。 

2. 静态 网 页 和 动态 网 页 

网 页 应 用 技术 种 类 繁多 ,根据 其 生成 方式 不 同 可 以 分 为 静态 页 面 和 动态 页 面 两 种 。 

(1) 静态 页 面 。 静 态 页 面 是 指 在 网 络 上 内 容 和 外 观 总 是 保持 不 变 的 页 面 ,这 些 网 页 大 
多 比较 简单 ,适合 表现 相对 固定 的 内 容 。 

(2) 动态 页 面 。 动 态 网 页 依靠 浏览 器 和 服务 器 端的 互动 来 实现 ,服务 器 端 可 以 实时 处 
理 浏览 器 端的 请 求 , 然 后 将 响应 结果 传 给 浏览 器 ,这 样 动态 页 面 就 显示 在 浏览 器 中 了 。 

ASP .NET 主要 用 来 制作 以 动态 网 页 为 主 的 应 用 系统 。 
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3. Web 窗 体 的 生命 周期 

Web 窗 体 从 实例 化 分 配 内 存 空间 到 处 理 结 束 释 放 内 存 ,一般 需要 经 历 4 个 步骤 。 

(1) 页 面 初始 化 : 页 面 生命 周期 中 的 第 一 个 阶段 是 初始 化 ,其 标志 是 Раве Init 事件 。 
当 页 面 初始 化 事件 发 生 时 ,. aspx 文件 中 的 声明 的 控件 被 实例 化 ,并 采用 各 自 默 认 值 。 

(2) 页 面 装载 : 页 面 装载 时 在 初始 化 之 后 进行 ,所 发 生 的 事件 为 Page_Load。 

(3) 事件 处 理 : Web 窗 体 上 的 每 一 个 动作 都 激活 一 个 到 达 服 务 器 的 事件 。 一 个 Web 
窗 体 有 两 个 视图 ,一 个 客户 视图 和 一 个 服务 器 视图 。 所 有 的 数据 处 理 都 在 服务 器 上 进行 。 
当 通 过 单 击 鼠 标 或 其 他 方法 触发 一 个 事件 时 ,事件 就 到 达 服 务 器 并 返回 相应 的 数据 。 

(4) 资源 清理 : 发 生 在 一 个 窗 体 完成 了 任务 并 准备 印 载 的 时 候 ,激活 Page_UnLoad 事 
件 , 完 成 最 后 的 资源 清理 。 


四 、 项 目 小 结 


本 章 包含 两 个 主要 内 容 , 第 一 个 是 安装 Visual Studio 2010 开发 工具 ,十 分 简单 ;第 二 个 
是 熟悉 Visual Studio 2010 开发 工具 ,简单 了 解 Visual Studio 2010 的 基本 操作 和 主要 窗口 和 
功能 。 随 着 学 习 的 深入 和 练习 的 增多 ,开发 工具 Visual Studio 2010 的 使 用 会 越 来 越 熟练 。 


五 、 项 目 考核 


1. 选择 题 

(1) 下 面 关于 ASP .NET 页 面 运行 过 程 描述 正确 的 是 ( Js 
A. 直接 运行 
B. 先 编译 后 执行 
C. 首先 编译 成 MSIL 语言 ,再 由 JIT 编译 器 编译 成 本 机 代码 
D. 以 上 都 不 正确 

(2) MSDN 是 一 种 ( Jia 


A. 注释 B. 随即 帮助 文档 
C. 系统 帮助 文档 D. 帮助 与 说 明 
(3) HTML 包括 ( ja 
A. 基本 标记 B. 文字 属性 标记 
C. 链接 标记 D. КАЙН bii 
(4) 在 ASP . NET 中 ,添加 了 两 个 最 基本 的 事件 (。  )。 
A. Form_Load B. Page_Load 
C. Page_UnLoad D. Click 
(5) 车 想 修改 按钮 显示 的 文字 名 字 , 应 当 设 置 按钮 的 ( ) 属 性 。 
A. Text B. Name 
C. Enableed D. Visible 
2. 填空 题 


(1) Visual Studio 2010 开发 工具 支持 的 开发 语言 有 
。16 . 


和 ë 


(2) Visual Stuido 2010 中 ,设计 页 面 的 后 缀 名 为 ,逻辑 代码 页 面 的 后 组 名 
为 5 

з. 简 答 

简 述 Visual Studio 2010 的 程序 开发 步骤 。 

4. 上 机 操作 题 


(1) 在 PC 上 安装 Visual Studio 2010, 

(2) 启动 和 退出 Visual Studio 2010 ,熟悉 Visual Studio 2010 的 界面 和 基本 操作 。 

(3) 模仿 本 项 目 任务 实施 中 的 过 程 ,开发 一 个 人 门 级 小 例子 。 例 如 ,可 以 输入 两 句 话 ， 
单 击 “提交 ?按钮 时 ,把 两 句 话 链接 起 来 并 一 同 输出 。 
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项 目 2 case 
一 、 引 言 


在 学 习 ASP .NET 之 前 ,需要 先 学 习 语 言 基础 ,ASP . NET 的 语言 有 多 种 ,包括 C# 语 言 、 
Visual Basic 语言 .C++ 语言 等 ,微软 公司 主推 的 是 C# 语 言 , 这 是 为 Web 开发 量 身 打造 的 语 
言 ,也 是 . NET 的 原生 语言 ,因此 本 书 也 采用 CHAR o 

本 项 目 是 为 没有 学 习 过 C# 语 言 或 C# 语 言 掌握 较 差 的 读者 准备 的 ,系统 学 习 过 C# 语 言 
的 读者 可 以 跳 过 本 章 。 


二 、 项 目 要 点 


(1) Т C# 语 言 基础 。 
(2) 掌握 C# 面 向 对 象 编程 和 C# 项 目 。 
(3) 掌握 C#i 河 言 的 核心 知识 和 技术 。 


三 任务 


任务 2-1 创建 三 种 经 典 应 用 程序 


【 任务 描述 】 
小 王 在 工作 中 使 用 过 很 多 应 用 程序 ,很 好 奇 应 用 程序 是 如 何 开 发 出 来 的 ,因为 他 还 不 知 
道 如 何 创建 应 用 程序 。 


【任务 目的 】 

(1) 了 解 CHR. 

(2) 掌握 简单 的 C# 程 序 书写 规范 。 

(3) 掌握 3 种 经 典 应 用 程序 的 创建 过 程 。 


【任务 分 析 】 

C# 是 进行 ASP . NET 开发 的 基础 ,首先 需要 掌握 C# 的 简单 书写 规范 , 方 可 进行 ASP . 
NET 程序 开发 设计 。 

【基础 知识 】 

1. C# 简 介 

C#( 读 做 C-sharp) 是 一 种 现代 化 的 面向 对 象 的 程序 开发 语言 ,由 微软 公司 为 . NET 平台 
设计 的 全 新 的 编程 语言 ,用 C# 编 写 的 应 用 程序 可 以 充分 利用 . NET 的 框架 体系 带 来 的 优点 ， 
可 以 使 程序 移植 到 . NET 上 。C# 是 Visual Studio 开发 工具 中 的 程序 设计 语言 之 一 , 既 可 以 用 
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来 编写 基于 通用 网 络 协议 的 Internet 服务 软件 ,也 可 以 编写 各 种 数据 库 、 网 络 服务 应 用 程序 
和 Windows 窗口 界面 程序 。 

C# 膏 言 的 优势 如 下 : 

(1) 具有 高 度 的 灵活 性 和 强大 的 底层 控制 能 力 ,能 与 计算 机 硬件 直接 通信 。 

(2) 具有 可 移植 性 ,尽管 程序 的 编写 是 针对 所 给 的 操作 系统 和 特定 的 计算 机 硬件 系统 
的 ,但 是 只 需要 做 少量 的 修改 就 可 以 应 用 于 其 他 系统 。 

(3) 代码 高 速 高 效 ,具有 相当 高 的 执行 效率 。 

知识 链接 : 目前 在 应 用 系统 开发 领域 ,市 场 份额 最 大 的 高 级 语言 是 C# 和 Javas CHH W 
响 近 年 来 越 来 越 大 。 

2. C#5 ASP .NET 的 关系 

. NET 是 一 个 抽象 层面 上 的 平台 的 概念 ,可 以 开发 .部署 和 执行 分 布 式 应 用 程序 ,其 本 
身 实现 的 方式 其 实 还 是 库 ,其 核心 就 是 . NET Framework, Mi ASP . NET 是 一 个 网 站 开发 的 
技术 ,是 . NET 框架 中 的 一 个 应 用 模型 ,是 用 于 生成 基于 Web 的 应 用 程序 的 内 容 丰 富 的 编程 
框架 。 

C# 就 其 本 身 而 言 只 是 一 种 程序 设计 语言 ,仅仅 是 为 了 方便 开发 人 员 和 计算 机 沟通 的 工 
具 , 其 使 用 和 与 . NET 的 关系 如 图 2-1 所 示 。 


~ 
amas 


托管 程序 集 (.exe 或 dll) MSIL 元 数据 


CLR 加 载 的 IL 元 数据 和 引用 


„МЕТ Framework. 


使 用 


转换 为 本 机 计算 机 代码 


图 2-1 С#5. NET 的 关系 


编写 的 ASP. NET 应 用 程序 通常 包括 网 页 层 和 后 台 处 理 层 这 两 部 分 的 代码 。 网 页 就 是 
用 标记 语言 来 写 的 ,完成 页 面 的 显示 ,而 网 页 对 应 的 后 台 处 理 程序 则 需要 . NET 语言 来 完 
成 ,目前 主要 是 采用 C# 语 言 。 可 以 说 整个 的 ASP . NET 网 站 通过 C# 来 实现 。 而 C# 则 是 MS 
.NET Framework 的 主要 语言 ,可 以 用 在 网 站 .桌面 应 用 等 方面 。 可 以 算是 一 种 比较 流行 的 
编程 语言 。 

3. 三 种 经 典 的 应 用 程序 

C# 主 要 用 于 开发 控制 台 应 用 程序 、Windows 窗 体 应 用 程序 和 Web 网 站 应 用 程序 这 
3 种 经 典 的 应 用 程序 ,在 新 建 项 目 中 可 以 选择 应 用 程序 的 种 类 ,如 图 2-2 所 示 。 在 图 2-2 中 ， 
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1,2,3 号 位 分 别 标记 出 控制 台 应 用 程序 .Windows 窗 体 应 用 程序 和 Web 网 站 应 用 程序 对 应 
的 位 置 , 单 击 这 3 个 位 置 ,可 创建 相应 的 应 用 程序 。 


ЖИТ Fronevork 4 ШЕКЕ [SG 


Tinio: 窗 体 应 用 程序 


[S] w umm 


Ф ASP.NET Dynamic Data 实体 Teb 应 用 程序 


Ө язны. м.т. 
"e теа 2010 Iff 
Tonsclelgplication? 
т BID 
MEREDEK 
ч 


图 22 三 种 经 典 应 用 程序 创建 位 置 


小 提示 : ASP .NET 是 开发 Web 网 站 应 用 程序 的 技术 ,也 是 本 书 的 核心 ,请 认真 学 习 相 
关 知 识 。 

控制 台 应 用 程序 是 Windows 系统 组 件 的 一 部 分 ,是 能 够 运行 在 MS-DOS 环境 中 的 程序 ， 
是 为 了 兼容 DOS 程序 而 设立 的 ,这 种 程序 的 执行 就 好 像 在 一 个 DOC 窗口 中 执行 一 样 ,没有 
可 视 化 的 界面 ,只 是 通过 字符 串 来 显示 或 者 监控 程序 。 控 制 台 程序 常常 被 应 用 在 测试 .监控 
等 方面 ,用 户 往往 只 关心 数据 ,不 在 乎 界面 。 
Windows 窗 体 应 用 程序 目前 是 在 微软 的 Windows 系统 中 使 用 最 多 的 应 用 程序 ,如 记事 
本 .画图 .计算 器 和 写字 板 等 。 这 类 程序 提供 了 友好 的 操作 界面 ,完全 可 视 化 的 操作 ,使 用 起 

当今 互联 网 已 经 改变 了 人 们 的 生活 方式 ,各 种 类 型 的 Web 应 用 充斥 着 互联 网 ,如 社交 
网 站 ,视频 网 站 ,博客 网 站 和 购物 网 站 等 。 通 过 . NET 平台 和 使 用 C# 语 言 ,可 以 构建 Web 应 
用 ,同时 在 .NET 平台 上 运行 的 Web 应 用 程序 的 技术 被 称 为 ASP .NET。 

【任务 实施 】 

第 1 步 ” 打 开 Visual Studio 2010 开发 环境 ,在 起 始 页 的 创建 操作 中 , 单 击 “ 新 建 项 目 ”， 
或 者 选择 “文件 "1“ 新 建 "1“ 项 目 " 菜 单 命令 ,弹出 “新 建 项 目 ”" 对 话 框 ,如 图 2-3 所 示 。 

第 2 步 ”在 “新 建 项 目 " 对 话 框 中 ,选择 项 目 类 型 中 的 Visual C#| Windows 选项 ,在 右边 
的 模板 列表 中 ,选择 “控制 台 应 用 程序 " 选项。 在 “名 称 " 字 段 中 ,填写 项 目 名 称 
ConsoleApplicationl ; 在 “位 置 "字段 中 , 单 击 * 浏 览 " 按 钮 ,选择 项 目 保 存 的 位 置 ;在 解决 方案 
名 称 字段 中 ,填写 解决 方案 的 名 称 ConsoleApplication1 。 单 击 * 确 定 "按钮 ,创建 一 个 控制 台 
应 用 程序 (也 可 单 击 图 2-2 中 的 1 号 位 置 来 完成 新 建 控制 台 项 目 ) ,如 图 2-4 所 示 。 
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FEAE 
最近 的 模板 
已 安装 的 模板 


в иза cë 


RM: Visul ce 
BTURReCGERHESHURH 


үт 浏览 器 应 用 程序 
аон 服务 
WT 用 户 控件 库 


Yr 自 定义 控件 库 
ы зла 
联机 模板 
Windows ЕЊЕ 


ConsoleApplicaticnl 
АЙЮ _ 
Consolehpplicatienl 


图 2-3 新建 控制 台 应 用 程序 


using System, Text 
Eimanespace Consolelpplicationl 


s P: 


< System Kol Ling 


@ тета 


图 24 第 一 个 控制 台 程序 


如 图 2-4 中 所 示 , 在 “解决 方案 "面板 中 ,系统 会 自动 生成 一 些 文件 和 代码 。 

Properties 是 项 目 属性 目录 ,其 中 存放 着 有 关 本 项 目 属性 的 类 。AssemblyInfo. cs 文件 中 
保存 项 目的 详细 信息 ,包括 项 目 名 称 、 项 目 描述 、 所 属 公司 版权 信息 以 及 版 本 号 等 。 

引用 目录 下 列 出 了 该 项 目 中 引用 的 所 有 类 库 。 

Program. cs 是 系统 默认 生成 的 生成 的 程序 开始 启动 文件 ,其 中 包含 了 程序 启动 的 静态 
方法 Main( ) , 即 人 口 函 数 。 
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第 3 步 ”打开 


建 一 个 新 类 后 ,系统 会 


Program. cs 文件 ,如 图 2-5 所 示 。 
第 1~4 行 : 在 使 用 类 之 前 ,必须 通过 using 关键 字 来 引用 . NET 类 库 中 的 命名 空 
默认 引用 4 个 最 常用 的 命名 空间 。 


х [а]. 0] 


命名 空间 提供 了 一 种 组 织 相关 类 


和 其 他 类 型 的 方式 ,是 用 来 组 织 类 的 ,用 来 防止 命名 冲突 。 


第 6 行 : namespace 关键 字 表 示 当 前 类 


第 10 行 : Main 是 程序 的 入 口 函 数 , 在 程序 运行 时 ,将 


+ 语言 相同 。 


类 所 属 的 命名 空间 。 


会 首先 执行 函数 中 的 代码 ,与 CC 


第 4 步 ” 按 快捷 键 Cul + F5 或 者 选择 “调试 " | “开始 执行 (不 调试 ) "菜单 命令 (如 图 2- 


6 所 示 ) ,编译 并 执行 代码 ,运行 效果 如 图 2-7 所 示 。 


1 Eusing System; 

2 |using System.Collections.Generic; 
j |using System. Ling; 

4 |using System. Text ; 
5 

[ 

T 


б Enamespace ConsoleApplicationl 


{ 

8E class Program 

9 

10 8 static void Main(string[] args) 

11 {| 

12 i 

13 H 

14 |] 
图 2-5 自动 生成 控制 台 应 用 程序 Program. es 文件 


°x C: MWINDOWSAsyst en32Vcnd. exe 


图 2-7 第 一 个 控制 台 


第 5 步 关闭 并 重新 打开 Visual Studio 2010 开发 环境 ,在 起 始 页 的 创建 指 
“新 建 项 目 ”, 或 者 选择 文件 "| 新 建 " | 项目 "菜单 


话 框 。 


Пахш Шла Әй ТА BRDO 
窗口 四 Я! 
b 启动 调 试 G) 15 
р 开始 执行 СЧА) Q0 Ctrl+F5 
к 启动 性 能 分 析 А DI 
G Волар O 
FRW Ctrl+D, E 
$z 逐 语句 人 0) Fi 
S Ww Fi0 
切换 断 点 (G) F9 
新 建 断 点 QD , 
Xo МЕТА O) CtrltShi ft+P9 
IntelliTrace (I) А 
清除 所 有 数据 提示 (A) 
导出 数据 提示 @) 
导入 数据 提示 (Р) 
选项 和 设置 G@) 


图 2-6 开始 执行 菜单 


?应 用 程序 执行 效果 


Ж Ер, ЫЕ 
弹出 图 2-3 所 示 的 “新 建 项 目 " 对 


命令 ， 


第 6 步 在 “新 建 项 目 " 对 话 框 中 ,选择 项 目 类 型 中 的 Visual C£ Windows 选项 ,在 右边 


的 模板 列表 中 ,选择 


用 程序 ) ,如 图 2-8 所 示 。 


Windows 窗 体 应 用 程序 "选项 。 ui 
WindowsFormsApplicationl ;在 "位置 "字段 中 , 单 击 “ 浏 览 

决 方案 名 称 字段 中 ,填写 解决 方案 的 名 称 WindowsFon нетни ë 
建 一 个 Windows 窗 体 应 用 程序 (也 可 单 击 图 2-4 中 的 2 号 位 置 来 完成 新 建 Windows 窗 体 应 


名 称 ” 字段 中 ,填写 项 目 名 称 
钮 ,选择 项 目 保存 的 位 置 ;在 解 
单 击 “ 确 定 "按钮 , 创 


如 图 2-8 中 所 示 ,在 “解决 方案 ”面板 中 ,系统 会 自动 生成 一 些 文件 和 代码 。 
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知识 链接 : Properties 是 项 目 属性 目录 ,其 中 存放 着 有 关 本 项 目 属性 的 类 。AssemblyInfo. cs 
文件 中 保存 项 目的 详细 信息 ,包括 项 目 名 称 、 项 目 描述 、 所 属 公司 .版权 信 息 以 及 版 本 号 等 。 
Resources. resx 和 Resources. Designer. cs 是 窗 体 的 资源 文件 。 Settings. settings 和 Settings. 
Designer. cs 是 项 目 属性 的 配置 文件 。 

引用 目录 下 列 出 了 该 项 目 中 引用 的 所 有 类 库 。 

Forml. es 是 窗 体 文件 ,其 中 包括 了 设计 器 和 窗 体 资源 文件 。 

Program. cs 是 系统 默认 生成 的 生成 的 程序 开始 启动 文件 ,其 中 包含 了 程序 启动 的 静态 
方法 Main( ) , 即 入 口 函 数 。 

如 图 2-8 中 所 示 ,在 “工具 箱 " 面板 中 ,将 所 使 用 的 控件 进行 分 类 。 选 择 工具 箱 中 的 一 个 
控件 ,将 此 控件 从 工具 箱 面板 中 拖 电 到 主 窗 体 中 的 任意 位 置 , 即 可 创建 该 控件 ,可 在 窗 体 中 
使 用 。 
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图 2-8 第 一 个 Windows 窗 体 应 用 程序 


第 7 步 ， 按 快捷 键 Ctrl + FS 或 者 选择 “调试 "1“ 开 
始 执行 (不 调试 ) "菜单 命令 (如 图 2-6 所 示 ) ,编译 并 执 
行 代码 ,运行 效果 如 图 2-9 所 示 。 

第 8 步 ” 关 闭 并 重新 打开 Visual Studio 2010 开发 
环境 ,在 起 始 页 的 创建 操作 中 , 单 击 “ 新 建 项 目 ” ,或 者 选 
择 “ 文 件 ”1“ 新 建 "1“ 项 目 " 菜 单 命 令 , 弹 出 图 2-10 所 示 
的 “新 建 项 目 ”" 对 话 框 。 

第 9 步 ”在 “新 建 项 目 " 对 话 框 中 ,选择 项 目 类 型 中 
的 Visual C#1 Web 选项 ,在 右边 的 模板 列表 中 ,选择 
“ASP .NET Web 应 用 程序 选项。 在“ 名称" 字段 中 ,十 
写 项 目 名称 WebApplicationl ;在 “位 置 "字段 中 , 单 击 “ 浏 


图 2-9 第 一 个 Windows 窗 体 应 用 
程序 执行 效果 
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新 建 项 目 
最近 的 模板 
已 安装 的 模板 
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图 2-10 新建 Web 应 用 程序 对 话 框 


览 " 按 钮 , 选择 项 目 保 存 的 位 置 ; 在 解决 方案 名 称 字 段 中 , 填写 解决 方案 的 名 称 
WebApplication1 。 单 击 “ 确 定 ” 按 钮 ,创建 一 个 Web 应 用 程序 (也 可 单 击 图 2-2 中 的 “3” 号 位 
置 来 完成 新 建 Web 应 用 程序 ) ,如 图 2-11 所 示 。 
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图 2-11 第 一 个 Web 应 用 程序 


如 图 2-11 中 所 示 ,在 “解决 方案 "面板 中 ,系统 会 自动 生成 一 些 文件 和 代码 。 
Properties 是 项 目 属性 目录 ,其 中 存放 着 有 关 本 项 目 属性 的 类 。AssemblyInfo. cs 文件 中 
保存 项 目的 详细 信息 ,包括 项 目 名 称 项目 描 述 .所 属 公司 版权 信 息 以 及 版 本 号 等 。 
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引用 目录 下 列 出 了 该 项 目 中 引用 的 所 有 类 库 。 

知识 链接 : Account 目录 是 系统 自动 生成 的 有 关 用 户 管理 的 代码 和 文件 ,如 用 户 登 录 、 
用 户 注 册 修改 密码 等 功能 。 

Web. config 是 项 目的 配置 文件 ,其 中 可 以 存放 连接 数据 库 等 信息 。 

Scripts 目录 中 是 Jquery 库 的 代码 ,Jquery 是 Ajax 的 技术 之 一 。 

Styles 目 录 中 是 站 点 的 样式 表 文 件 。 

About. aspx 是 系统 生成 的 关于 页 面 。 

Default. aspx 是 站 点 的 默认 起 始 页 面 。 

Global. asax 文件 中 记录 着 站 点 的 全 局 变量 。 

Site. Master 是 一 个 母 版 文件 ,类 似 于 框架 。 

如 图 2-11 中 所 示 ,在 "工具 箱 " 面 板 中 ,将 所 使 用 的 控件 进行 分 类 。 选 择 工 具 箱 中 的 一 
个 控件 ,将 此 控件 从 “工具 箱 ” 面板 中 拖 蝶 到 页 面相 应 位 置 , 修 改 标签 属性 , 即 可 使 用 该 控件 
(具体 方法 在 拓展 提高 中 介绍 ) 

第 10 步 ” 按 Cul+F5 键 或 者 选择 “调试 "1* 开 始 执 行 (不 调试 )" 菜 单 命 令 ( 如 图 2-7 所 
示 ) ,编译 并 执行 代码 ,运行 效果 如 图 2-12 所 示 。 


3032490808 6.3 文件 查看 sm IR Wb w 一 O x 
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我 的 ASP.NET 应 用 程序 


欢迎 使 用 ASP.NETI! 
车 要 了 解 关于 ASP NET 的 详细 信息 ， 请 访问 www ар net/cn. 
您 还 可 以 找到 MSDN 上 有 关 ASP NET 的 文档 。 


图 2-12 第 一 个 Web 应 用 程序 运行 效果 


【任务 小 结 】 

本 任务 介绍 CHH CH ASP . NET 的 关系 ,重点 介绍 C# 经 常 使 用 的 3 种 经 典 应 用 程 
序 的 创建 和 配置 。C# 是 ASP . NET 开发 的 首要 选择 使 用 语言 , 需 掌握 其 3 种 经 典 应 用 程序 
的 创建 和 执行 。 

【拓展 提高 】 

1. 控制 台 应 用 程序 中 输出 “Hello World" 

第 1 步 打开 Visual Studio 2010 开发 环境 ,执行 “文件 "1* 打 开 ”1“ 项 目 /解决 方案 " 命 
令 , 弹 出 “打开 项 目 " 对 话 框 , 如 图 2-13 所 示 。 

第 2 步 ” 选 择 ConsoleApplicationl 文件 夹 下 的 ConsoleApplicationl. sln 解决 方案 , 单 击 
“打开 ”按钮 ,将 任务 中 的 第 一 个 控制 台 应 用 程序 打开 。 

第 3 步 打开 Program. cs XF, ÆA O Р Main ( ) 中 添加 代码 “Console. WriteLine 

+25. 
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图 2-13 “打开 项 目 " 对 话 框 


("Hello World!" ) ; ”并 保存 文档 ,更 改 后 的 文档 如 图 2-14 所 示 


1 Busing System; 

2 |using System.Collections.Generic; 
) |using System. Linq; 

4 [using System. Text; 
5 


6 Enamespace Console4pplicationl 


日 class Program 
9 { 
10 8 static void Main(string[] args) 
11 { 
12 4 输出 到 控制 人 | 
13 Console. WriteLine (“Hello World!"). 
14 } 
15 i 
16 |] 


图 2-14 控制 台 应 用 程序 添加 输出 语句 


Console 是 有 关 控 制 台 的 类 ,有 两 个 输出 字符 串 的 方法 ,其 中 示例 中 使 用 的 WriteLine 方 
是 将 字符 串 输出 到 控制 台中 显示 出 来 ,结尾 会 有 一 个 换行 控制 符 一 起 输出 出 来 ; 另 一 个 方 
法 为 Write ,也 可 将 字符 串 输出 到 控制 台中 显示 ,但 结尾 没有 换行 控制 符 。 
第 4 步 FE CuleFS 键 或 者 选择 “调试 " | 开始 执行 (不 调试 ) ”菜单 命令 (如 图 2-6 所 
示 ) ,编译 并 执行 代码 ,运行 效果 如 图 2-15 所 示 。 


:\FINDO¥S\system32\cad. exe 


图 2-15 控制 台 应 用 程序 中 输出 “Hello World" 


2. Windows 窗 体 应 用 程序 中 输出 “ Hello World" 

第 1 步 选择 "文件 "上 打开 "上 * 项 目 /解决 方案 "菜单 命令 ,弹出 “打开 项 目 " 对 话 框 ， 
如 图 2-13 所 示 。 

第 2 步 选择 WindowsFormsApplicationl 文件 夹 下 的 WindowsFormsApplication1. sln 解决 
方案 , 单 击 “ 打 开 ”" 按 钮 ,将 任务 中 的 Windows 窗 体 应 用 程序 打开 。 

第 3 步 ETRA” 面板 中 选中 Label 控件 拖 中 至 主 窗口 中 的 任意 位 置 ,如 图 2-16 
所 示 。 
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图 2-16 Hi Label 控件 
第 4 步 ”选择 刚才 放 到 主 窗 体 的 Label 控件 ,在 “属性 "面板 中 设置 其 Text 属性 为 Hello 
World 并 保存 文档 ,修改 后 的 文档 如 图 2-17 所 示 。 
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图 2-17 更 改 Label 属性 
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第 5 步 FR Cil +FS 键 或 者 选择 “调试 "|* 开 始 执行 (不 调试 ) ”菜单 命令 (如 图 2-6 所 
示 ) ,编译 并 执行 代码 ,运行 效果 如 图 2-18 所 示 。 

3. Web 应 用 程序 中 输出 “Hello World" 

第 1 步 选择 “文件 ”1“ 打 开 ”"1“ 项 目 / 解 决 方案 ” 
菜单 命令 ,弹出 “打开 项 目 " 对 话 框 。 

第 2 步 选择 WebApplicationl 文件 夹 下 的 
WebApplication1. sln 解决 方案 , 单 击 “打开 ”按钮 ,将 任 
务 中 的 Web 应 用 程序 打开 。 

第 3 步 ”在 “工具 箱 "面板 中 选中 Label 控件 拖 电 至 
“div 标签 中 (类 似 功能 标签 ) ”, 如 图 2-19 所 示 。 

第 4 步 ” 修改 Label 标签 的 Text 属性 为 Hello World 


并 保存 文档 ,修改 后 的 文档 如 图 2-20 所 示 ( 第 8 行 代 12-18 Windows 窗 体 应 用 程序 
1) A 中 输出 “Hello World" 


Hello World 
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图 2-19 4652 Label 控件 


<%@ Page Тїї1е= EN” Language- CP" MasterPageFile-" /Site.master" AutoEventWireup- true" 
CodeBehind-"Default.aspx.cs" Inheritsz"Vebápplicationl. Default" Ж> 


1 

3 

4 《asp:Content ID-"HeaderContent" runat="server" ContentPlaceHolderID-"HeadContent^? 
5 “/asp:Content> 

6 EXasp:Content ID-"BodyContent" runat="server" ContentPlaceHolderID-"MainContent" 

1 
8 


в «2 
欢迎 使 用 ASP. МЕТ! <asp:Label ID-"Labell" runat="server" Text-^Hello World'»X/asp:Label? 
9 </h2> 
10 D <p> 
11 | 著 要 了 解 关于 ASP.NET 的 详细 信息 ， 请 访问 <a href- http://www.asp.net/cn title="ASP. МЕТ 网 站 “>www, asp. net/cn</a>o 
12 </p> 
155 «Ф 
14 您 还 可 以 找到 <a href-"http://go. microsoft, con/fvlink/?LinkID-152368" 
15 title="MSDN ASP.NET 文档 ">MSDN E ASP.NET 的 文档 </a>。 
16 «р> 
17 [4/asp:Content? 


Р 2-20 更 改 Label 标签 Text 属性 


第 5 步 TR Cul +FS 键 或 者 选择 “调试 " | * 开 始 执行 (不 调试 ) "菜单 命令 (如 图 2-6 所 
示 ) ,编译 并 执行 代码 ,运行 效果 如 图 2-21 所 示 。 
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图 2-21 Web 应 用 程序 中 输出 Hello World 


任务 2-2 掌握 C# 数 据 类 型 


【任务 描述 】 

小 王刚 学 习 开 发 ,不 知道 数据 在 程序 中 如 何 记录 和 使 用 ,查找 资料 后 得 知 , 使 用 变量 保 
存 数据 的 值 ,他 想 知道 : 不 同 数据 类 型 ,比如 姓名 \ 年 龄 .出 生日 期 等 ,是 否 该 使 用 不 同类 型 
的 变量 。 

【任务 目的 】 

了 解 C# 语 言 数 据 类 型 分 类 。 

掌握 值 类 型 数据 类 型 的 应 用 。 

理解 引用 类 型 数据 类 型 的 应 用 。 


【任务 分 析 】 

数据 类 型 定义 一 个 数据 属于 哪 种 类 型 ,在 程序 执行 时 ,操作 系统 会 分 配 一 块 内 存 给 应 用 
程序 存储 相关 的 数据 。 内 存 是 有 限 的 资源 , 若 已 填 满 数据 ,其 他 要 存储 的 数据 必须 等 某 些 数 
据 不 用 、 有 多 余 的 空间 时 才能 存 入 ,所 以 在 程序 设计 时 ,根据 数据 特性 及 预 估计 范围 选 一 个 
适合 的 数据 类 型 是 必要 的 。 

【基础 知识 】 

1. 数据 类 型 分 类 

类 型 是 某 类 数据 的 总 称 ,用 于 确定 存储 何 种 信息 以 及 能 存储 多 少 信息 等 , 它 定义 了 数据 的 

性 质 、 取 值 范围 以 及 对 数据 所 能 进行 的 各 种 操作 。C# 是 一 种 强 类 型 编程 语言 ,在 声明 每 个 
变量 和 常量 都 要 明确 指定 它 的 数据 类 型 ,以 便 编译 器 为 其 分 配 内 存 空间 。 同 时 ,每 个 计算 为 
值 的 表达 式 也 需要 指定 数据 类 型 ,每 个 方法 需要 为 每 个 输入 参数 和 返回 值 指定 一 个 类 型 。 

C# 砍 言 的 数据 类 型 主要 分 为 两 类 : 值 类 型 和 引用 类 型 。 

值 类 型 变量 本 身 包 含 它 们 的 数据 ,而 引用 类 型 变量 包含 的 是 指向 包含 数据 的 内 存 块 的 
引用 或 者 叫 句柄 。 从 概念 上 看 ,其 区 别 是 值 类 型 直接 存储 其 值 ,而 引用 类 型 存储 对 值 的 
引用 。 
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值 类 型 存储 在 堆栈 上 ,而 引用 类 型 存储 在 托管 堆 上 ,要 注意 区 分 某 个 类 型 是 值 类 型 还 是 


引用 类 型 , 因为 存储 位 置 的 不 同 会 有 不 同 的 edd: 
影响 。 КЕ 

值 类 型 可 以 分 为 简单 类 型 结构 类 型 和 枚 举 aa 布尔 美 型 
类 型 三 大 类 。 其 中 ,简单 类 型 分 为 整数 类 型 . 字 жш sawa KARA 
符 类 型 ,布尔 类 型 和 实数 类 型 4 种 。 引 用 类 型 分 _ Be 
为 类 .委托 .数组 和 接口 4 种 类 型 。 数 据 类 型 的 、 获 提 类 型 类 类 型 

I а ^ 类 字符 串 类 型 
结构 图 如 图 2-22 Bir , 值 类 型 和 引用 类 型 之 间 的 | 委托 | 对 象 类 型 
关系 之 间 的 关系 如 图 2-23 所 示 。 amem. 数组 

2. 值 类 型 接 

在 具体 讲解 值 类 型 之 前 , 先 了 解 一 下 变量 的 图 2.22 C4 的 数据 类 型 结构 图 


概念 。 从 用 户 的 角度 来 看 ,变量 就 是 存储 信息 的 
基本 单元 ;从 系统 的 角度 来 看 ,变量 就 是 计算 机 内 存 中 的 一 个 存储 空间 。 
引用 类 型 


System.Object 


值 类 型 


所 有 结构 ， 包 括 
内 置 数 值 类 型 


图 2-23” 值 类 型 和 引用 类 型 之 间 的 关系 


值 类 型 最 大 的 特点 在 于 值 类 型 变量 中 都 直接 存储 了 自己 的 数据 ,对 值 类 型 变量 的 操作 
就 是 直接 修改 变量 中 存储 的 数据 ,而 且 对 某 个 变量 的 操作 不 会 影响 其 他 变量 的 值 。 下 面 简 
单 介 绍 值 类 型 的 简单 类 型 结构 类 型 枚 举 类 型 这 三 大 类 。 

(1) 简单 类 型 。 从 计算 机 的 角度 来 看 ,简单 类 型 可 分 为 整数 类 型 .实数 类 型 .字符 类 型 
和 布尔 类 型 。 

小 提示 : 在 应 用 程序 中 ,使 用 最 多 的 数据 类 型 是 字符 串 (string) 、 整 数 (int) 、 浮 点 数 
(double) 和 日 期 (date) 等 类 型 。 

CD 整数 类 型 。 顾名思义 ,整数 类 型 变量 的 值 为 整数 。 数 学 上 的 整数 可 以 从 负 无 穷 大 到 
正 无 穷 大 ,但 是 由 于 计算 机 的 存储 单元 是 有 限 的 ,所 以 计算 机 语言 提供 的 整数 类 型 的 值 总 是 
在 一 定 的 范围 之 内 。 
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整数 类 型 是 C# 数 值 类 型 的 一 种 ,C# 支 持 8 种 整数 类 型 ,分 别 是 字 节 型 (byte) 、 短 字 节 型 
(sbyte) JERAI ( ushort) 、 整 型 (int) .长 整 型 (long) .无 符号 短 整 型 (ushort) 、 无 符号 整 型 
(uint) \ 无 符号 长 整 型 (ulong) ,如 表 2-1 所 示 。 


表 2-1 “CH# 整 数 类 型 
C# 基 本 类 型 | 类 型 说 明 范围 
byte 8 位 无 符号 整 型 | 0 ~255(0 ~2 -1) 
sbyte 8 位 有 符号 整 型 | -128 ~127( -27 ~27 -1) 
short 16 位 有 符号 整 型 | -32 768 ~32 767( -25 ~25 -1) 
int 32 位 有 符号 整 型 | -2 147 483 648 -2 147 483 647( -23 ~23 -1) 
long 64 位 有 符号 整 型 | -9 223 372 036 854 775 808 ~9 223 372 036 854 775 807( -29 -2% -1) 
ushort 16 位 无 符号 整 型 | 0 ~65 535(0 -2^ -1) 
uint 32 位 无 符号 整 型 | 0 ~4 294 967 295(0 ~22 -1) 
ulong 64 位 无 符号 整 型 | 0 ~ 18 446 744 073 709 551 615(0 -2* -1) 


int long 等 都 是 常用 的 类 型 ,long 型 是 整 型 类 型 中 最 长 的 ,其 次 是 int 型 ,再 短 的 则 是 
short 类 型 ,这 3 种 都 代表 有 符号 的 整数 类 型 ,与 之 相反 , 即 没有 符号 的 则 是 ulong, uint, 
ushort。 如 果 对 一 个 整 型 变量 是 int ,uint , long 或 者 ulong 没有 任何 显示 声明 ,那么 这 个 变量 
默认 为 int 类 型 。 

@ 实数 类 型 。 实 数 型 数据 又 称 为 浮 点 型 数据 ,C# 中 的 是 实数 型 包含 单 精度 浮 点 型 
(float) 、 双 精度 浮 点 型 (double) 和 固定 精度 浮 点 型 (decimal)3 种 ,如 表 2-2 所 示 。 


X22 СЕ ЖШ 
C# 基 本 类 型 类 型 说 明 范 M 
decimal 有 28 位 小 数 的 高 精度 浮 点 数 £1.0x1077 ~ 27.9 x10” 
single( float ) 单 精度 浮 点 类 型 £1.5x1075 ~ 23.4 x10” 
double 双 精 度 浮 点 类 型 +5.0 x107” ~ 21.7 x10% 


实数 类 型 的 3 种 数据 类 型 的 主要 区 别 在 于 取 值 范 围 和 精度 不 同 。 计 算 机 对 浮 点 数 的 运 
算 速 度 大 大 低 于 对 整数 的 运算 速度 ,在 对 精度 要 求 不 是 很 高 的 情况 下 ,最 好 采用 float 类 型 ， 
即 float 类 型 适用 于 较 小 的 浮 点 数 , 它 的 小 数位 数 仅 有 7 位 ,而 double 类 型 比 float 类 型 的 精 
度 要 高 一 倍 (15 位 )。 但 会 占用 更 多 的 内 存单 元 ,处 理 速 度 也 会 相对 较 慢 。 精 度 最 高 的 是 
decimal 数据 类 型 ,其 精度 可 以 达到 28 位 小 数位 ,这 是 C# 专 门 提供 给 金融 和 货币 方面 计算 
的 数据 类 型 。 使 用 浮 点 类 型 时 要 注意 , 赋 给 float double decimal 类 型 的 值 必须 在 最 后 追加 
一 个 字母 ,字母 定义 如 下 : 

浮 点 型 数据 表示 : 

1.20f IREKE F 

双 精 度 型 数据 表示 : 


12.5d // 或 者 大 写 D, 不 追加 字母 也 可 以 ,默认 为 doible 类 型 
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固定 精度 浮 点 型 数据 表示 : 

25.7 // 或 者 大 写 M 

@ 字符 类 型 。 除 了 数字 以 外 ,计算 机 处 理 的 信息 主要 就 是 字符 ,字符 包括 数字 字符 ОЖ 
文字 母 和 表达 符号 等 。 在 过 去 用 于 计算 机 内 的 字符 集 是 ASCH 码 , 现 在 C# 提 供 的 字符 类 型 
按照 国际 上 公认 的 标准 ,采用 Unicode 字符 集 。 一 个 Unicode 字符 集 的 标准 字符 长 度 为 16 
位 ,用 它 可 以 表示 世界 上 大 多 数 语言 。 

字符 型 的 常量 在 使 用 时 必须 加 上 单 引 号 ,可 以 按 如 下 方法 给 字符 变量 赋值 。 例 如 : 

dar s-'A'; 

男 外 ,还 可 以 直接 通过 十 六 进 制 转 义 符 (前 级 \x) 或 Unicode 表示 法 (前 级 \u) 给 字符 变 
量 赋值 。 例 如 : 


char s=" \х0032'; 
char s =' N0032'; 


与 C/C ++ 中 一 样 ,在 C# 中 也 存在 转 义 符 ,用 来 在 程序 中 指 代 特 殊 的 控制 字符 , 如 
表 2-3 所 示 。 


X23 C# 中 的 转 义 符 


转 义 序列 字符 说 明 转 义 序列 字符 说 明 转 义 序列 字符 说 明 
V 单 引 号 \a 警告 \г 回 车 
\" 双 引 号 \b 退 格 T 水 平 制 表 符 
NN 反 斜 杠 M 换 页 Ww 垂直 制 表 符 
\0 空 \n 换行 


注意 : 在 C/C ++ 中 字符 型 变量 的 值 是 该 变量 所 代表 的 АЅСП 码 , 字 符 型 变量 的 值 作为 
整数 的 一 部 分 ,可 以 对 字符 型 变量 使 用 整数 进行 赋值 和 运算 ,而 这 在 C# 中 是 禁止 的 。 

@ 布尔 类 型 。 布 尔 类 型 只 含有 两 个 数值 : true 和 false, 即 真 或 者 假 。 

注意 ; 在 C/C ++ 中 用 0 来 表示 “ 假 " ,其 他 任何 非 0 的 式 子 都 表示 为 “ 真 " ,这 种 不 正规 
的 表达 在 C# 中 已 经 被 废弃 了 。 在 СЕР пие 值 不 能 被 其 他 任何 非 零 值 所 代替 。 值 得 注意 的 
是 ,布尔 类 型 与 整数 类 型 完全 不 同 , 布 尔 值 不 能 够 用 在 需要 整数 值 的 地 方 , 反 之 亦 然 。 在 布尔 
类 型 和 整数 类 型 之 间 不 存在 任何 转换 ,将 整数 类 型 转换 成 布尔 类 型 也 是 不 合法 的 。 例 如 : 

bolis;  // 错 误 , 不 存在 这 种 写法 ,只 能 取 值 te 或 false 


(2) 结构 类 型 。 将 一 系列 相关 的 变量 组 织 成 为 一 个 单一 实体 的 过 程 称 为 生成 结构 的 过 
程 。 这 个 单一 实体 的 类 型 就 叫做 结构 类 型 。 结 构 类 型 可 以 由 不 同类 型 的 元 素 组 成 ,每 一 个 
元 素 称 为 成 员 或 域 。 在 结构 类 型 中 为 每 个 成 员 指定 了 一 个 名 称 和 数据 类 型 ,结构 可 以 包含 
ЖЫРА 5 ( constructors ) .常量 (constants) „2 ( fields) 方法 (methods) ,特征 ( properties) , F bi 
(indexers) .操作 符 (operators ) URREZK! ( nest types) 。 它 在 形式 上 和 后 面 介绍 的 引用 类 
型 中 的 类 类 型 ( class types ) 很 相似 。 结 构 类 型 和 类 类 型 最 大 的 区 别 就 是 ,结构 类 型 是 值 类 型 
而 类 类 型 是 引用 类 型 。 
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结构 类 型 在 创建 诸如 点 结构 文件 类 型 结构 .通讯 录 结 构 等 一 些小 型 对 象 时 特别 灵活 。 
结构 类 型 数据 通常 直接 存储 在 内 存 中 ,数据 的 存 取 特 别 快捷 ,有 利于 提高 运行 速度 。 但 是 如 
果 是 存储 大 量 数据 的 结构 数组 ,就 可 能 造成 内 存 资源 紧张 。 在 这 种 情况 下 ,就 要 使 用 类 类 型 
数据 ,因为 类 中 的 数据 是 动态 编译 的 ,只 有 当前 使 用 的 数据 才 放 到 内 存 中 使 用 。 

结构 类 型 的 定义 方式 如 下 : 


[附加 声明 信息 ] [访问 修饰 符 ] struct 结构 名 [: 包含 结构 所 实现 接口 的 列表 ]{ 结 构 体 } 
其 中 带 有 方 括号 ([ ] ) 的 部 分 是 可 选项 。 即 可 有 可 无 。 

访问 修饰 符 表达 不 同 的 保护 级 别 : public protected internal , protected internal 和 private。 

比如 ,通讯 录 的 记录 中 可 以 包含 他 人 的 姓名 .电话 .生日 和 地 址 。 如 果 按 照 简单 类 型 来 
管理 ,每 条 记录 都 要 存放 到 3 个 不 同 的 变量 当中 ,这 会 造成 很 大 的 工作 量 , 且 不 够 直观 。 我 
们 可 以 定义 通讯 录 记 录 结 构 为 : 


struct FhoneBook 

( 
Püblic string name; // 姓 名 
Public string phone; // 电 话 
Public DateTime birthday; // 生 日 
Public string address; // 地 址 

} 

PhoneBook pq; 


pq 就 是 一 个 PhoneBook 结构 类 型 的 变量 ,对 结构 类 型 的 成 员 的 访问 ,可 以 通过 结构 变 
量 加 上 “. "后 面 跟 成 名 的 名 称 。 例 如 ,现在 要 给 结构 体 中 的 name 成 员 赋 一 个 “ 张 三 ” 的 字符 
串 , 我 们 可 以 这 样 赋值 : 


ра.пате =" = "; 


(3) 枚 举 类 型 。 枚 举 类 型 是 一 种 独特 的 值 类 型 ,用 于 声明 一 组 命名 的 常数 , 即 系统 把 相 
同类 型 .表达 固定 含义 的 一 组 数据 作为 一 个 集合 放 到 一 起 形成 一 个 新 的 数据 类 型 。 

例如 ,可 以 把 一 个 星期 的 7 天 放 到 一 起 形成 一 个 新 的 数据 类 型 来 描述 星期 ,那么 这 个 新 
的 数据 类 型 就 是 一 个 枚 举 类 型 。 实 际 上 , 枚 举 就 是 为 一 组 在 逻辑 上 密 不 可 分 的 整数 值 提供 
便于 记忆 的 符号 。 

枚 举 类 型 的 变量 采用 enum 关键 字 进 行 声明 ,比如 可 以 把 一 个 星期 的 结构 定义 如 下 : 


enum WeekDay 

{ 
Marcy, 
Tuesday, 
Wednesday, 
Thursday, 
Friday, 
Satuarday, 
Sunday 
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WeekDay cay; 

注意 : 结构 类 型 是 由 不 同类 型 的 数据 组 成 的 一 组 新 的 数据 类 型 ,结构 类 型 变量 的 值 是 
各 个 成 员 的 值 组 合 而 成 的 ;而 枚 举 则 不 同 , 枚 举 类 型 的 变量 在 某 一 时 刻 只 能 取 枚 举 中 的 某 一 
个 元 素 的 值 。 

比如 day 这 个 表示 星期 的 枚 举 类 型 的 变量 , 它 的 值 只 能 从 一 周 的 7 天 中 选取 一 个 值 ,而 
不 能 是 两 个 值 ,例如 : 

day -Sunday; 

按 系统 默认 , 枚 举 中 的 每 个 元 素 类 型 都 是 int 类 型 ,而 且 第 一 个 元 素 删 去 的 值 为 0, 它 后 


面 的 每 个 连续 元 素 的 值 按 加 1 递增 ,在 枚 举 类 型 中 也 可 以 给 元 素 直 接 赋值 。 
例如 下 面 的 程序 ,将 Monday 的 值 设 定 为 1 ,其 后 元 素 的 值 分 别 为 1,2,…: 


enum WeekDay 

{ 

Monday =1, 
Tuesday, 
Sray 

}; 

WeekDay day; 

为 枚 举 类 型 的 元 素 所 赋 的 值 的 类 型 限于 long int short 和 byte 等 整数 类 型 。 

3. 引用 类 型 

和 值 类 型 相 比 , 引 用 类 型 不 存储 它们 所 代表 的 实际 数据 ,而 是 存储 世界 数据 的 引用 。 

(1) 类 类 型 。 类 类 型 定义 了 一 个 包括 数据 成 员 ( 常数 \ 域 和 事件 ) .函数 成 员 ( 方 法 、 属 
性 索引、 操作 符 ,构造 函数 和 析 构 函数 ) 和 嵌 套 类 型 。 类 类 型 支持 继承 ,因为 这 种 机 制 派生 
的 类 可 以 对 基 类 进行 继承 和 扩展 。 使 用 对 象 创建 表达 式 来 创建 类 类 型 的 实例 。 

(2) 对 象 类 型 。 面 向 对 象 的 语言 大 都 提供 一 个 根 类 型 ,层次 结构 中 的 其 他 对 象 都 从 它 
派生 而 来 。C# 就 中 的 这 个 根 类 型 就 是 System. Object, 所 有 内 置 类 型 和 用 户 定义 的 类 型 都 从 
它 派生 而 来 。 这 样 ,对 象 类 型 就 可 以 用 于 两 个 目的 : 一 是 可 以 使 用 Object 引用 绑 定 任何 子 类 
型 的 对 象 ; 二 是 对 象 类 型 之 行 许多 一 般 用 途 的 基本 方法 ,包括 Equals ( ) , GetHashCode ( ) , 
GetType( ) 和 ToString( ) 。 

(3) 字符 串 类 型 。 字 符 串 类 型 是 编程 中 经 常 使 用 的 一 种 类 型 ,但 是 在 C 或 C ++ 中 字符 
串 只 是 一 个 字符 数组 ,使 用 起 来 极 不 方便 。C# 提 供 了 自己 的 字符 串 类 型 ,这 对 字符 串 的 操 
作 , 如 复制 拼接 等 就 变 得 非常 简单 。 例 如 : 

string stri “RHA FE" 

string str2 ="Lilei"; 

string str3 -strl 4st12; 

字符 串 类 型 是 应 该 被 引用 的 类 型 string 对 象 保存 在 堆 上 ,因此 , 当 把 一 个 字符 串 变 量 赋 
给 另 一 个 字符 串 时 ,会 得 到 对 内 存 中 同一 个 字符 串 的 两 个 引用 。 

常量 字符 串 的 值 必须 用 双 引号 括 起 来 ,如 果 使 用 单 引 号 ,系统 就 会 将 它 当 做 字符 类 型 ， 
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从 而 引发 错误 。 

C# 还 提供 了 一 种 替代 方式 ,就 是 在 字符 串 的 前 面 加 上 “@ " ,在 这 个 字符 后 的 所 有 字符 
都 被 看 做 是 其 本 来 的 含义 ,而 不 解释 为 转 义 符 , 例 如 : 

string filename =@"С: MyDoaurents Va doc"; 

(4) 接口 类 型 。 一 个 接口 定义 一 个 协定 ,实现 接口 的 类 或 结构 必须 遵守 其 协定 。 一 个 
接口 也 许 会 从 多 个 基本 接口 继承 ,而 一 个 类 或 结构 可 以 实现 多 个 接口 。 

(5) 数组 类 型 。 所 谓 数组 就 是 有 序 的 、 同 一 类 型 数据 的 集合 。 数 据 是 包含 多 个 变量 的 
数据 结构 ,这 些 变 量 称 为 数组 的 元 素 ,数组 元 素 可 以 通过 索引 值 进行 访问 。C# 语 言 中 的 数 
组 是 从 0 开始 的 ,数组 元 素 必须 有 相同 的 类 型 。 

数组 声明 主要 是 声明 数组 的 名 称 和 数组 所 包含 的 元 素 的 数据 类 型 或 元 素 的 类 名 。C# 
支持 一 维 数组 和 多 维 数组 。 

在 C# 语 言 中 ,一 维 数组 的 声明 语法 格式 如 下 : 

数组 元 素 类 型 [] 数组 名 ; 

其 中 ,数组 元 素 类 型 可 以 为 C# 中 任意 的 数据 类 型 。 数 组 名 为 一 个 合法 的 标识 符 ,[ ] 指明 该 
变量 是 一 个 数组 类 型 变量 。 例 如 : 

int[] myArray; 

与 C/C++ 不 同 ,C# 在 数组 的 定义 中 并 不 为 数组 元 素 分 配 内 存 ,因此 [ ] 中 不 能 指出 数组 
元 素 的 个 数 ,而 且 , 对 于 上 面 定义 的 一 个 数组 是 不 能 访问 它 的 任何 元 素 的 ,在 其 前 必须 使 用 
运算 符 new 为 它 分 配 内 存 空间 ,其 格式 为 : 

数组 名 =new 数组 类 型 [arraySize]; 

其 中 ,arraySize 指明 数组 的 元 素 个 数 。 例 如 : 

myarray =пем int[7]; 

多 维 数组 的 声明 方式 如 下 : 

数组 元 素 类 型 [,] 数组 名 ; 

通常 ,也 可 以 像 一 维 数组 那样 ,定义 与 内 存 分 配合 在 仪器 ,例如 ,下 面 的 声明 创建 了 一 4 
行 2 列 的 二 维 数组 : 

int [,] myArray -new int [4,2]; 

可 以 在 声明 数组 时 进行 数组 初始 化 ,例如 : 

int [] myArray =пем int (] (1,2,3,4,5); 

int [,] numbers =w int [3,2] (1,2), (3,4), (5,6) }; 

(6) 委托 类 型 。 委 托 是 一 种 指向 一 个 静态 方法 或 一 个 对 象 的 对 象 实例 和 对 象 方法 的 数 
据 结构 。 

ТЕС 或 C++ 中 与 委托 相同 的 是 函数 指针 ,但 是 功能 指针 只 能 指向 静态 函数 ,而 委托 可 
以 指向 静态 和 实例 方法 。 委 托 不 仅 存储 对 于 方法 的 人口 点 的 引用 ,同时 也 存储 对 调用 方法 
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的 对 象 实例 的 引用 。 


【任务 实施 】 
SRI 新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_1。 在 人口 函数 Main( ) 中 添加 代码 : 


首先 声明 两 个 整数 类 型 变量 i 和 j ,并 赋值 500 .100; 然 后 定义 变量 k, 并 设置 其 值 的 计算 方 


法 


;最 后 使 用 控制 台 类 Console 把 变量 k 的 值 输出 到 控制 台 并 显示 。 代 码 如 下 : 
01 using System; 
02 using System.Collections.Generic; 
03 using System.Ling; 


04 using System. Text; 
05 namespace cha2 1 


06 ( 
07 class Program 
08 { 
09 static void Маїп (string[] args) 
10 { 
11 int і =500; 
12 int j-100; 
13 int k=i +j; 
14 Console.Write ("500 +100 ="); 
15 Console.WriteLine (К); 
16 } 
17 } 
18} 
其 中 


第 11 和 12 行 分 别 定义 了 两 个 整数 类 型 变量 1 和 j 并 赋值 5000 .100。 
第 13 行 定义 整数 类 型 变量 k 并 将 i 和 j 的 和 赋值 给 k 
第 14 行使 用 Console 类 的 Write( ) 方 法 表示 输出 字符 串 到 控制 台中 ,但 是 结尾 处 没有 换行 


[在 Write( ) 方 法 时 ,使 用 双 引 号 表示 字符 串 , 内 容 (500 + 100 = ) 在 双 引号 内 部 定义 。 


第 15 行 输出 变量 k 的 值 。 
第 2 步 ”编译 并 运行 代码 ,运行 结果 如 图 2-24 所 示 。 


©\ C: MITRDOWSAsysten32Vcnd. exe [-|B[ x] 


图 224 整数 类 型 的 应 用 


图 2-24 展示 了 程序 实现 了 两 个 整数 之 间 的 加 法 运算 , 且 运 算 结 果 正 确 。 
第 3 步 ”新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_2。 在 入 口 函 数 Main C) 中 添加 代码 : 


首先 声明 两 个 字符 类 型 变量 cl 和 c2 ,并 赋值 ;然后 使 用 控制 台 类 Console 把 变量 c1 和 c2 的 
值 输出 到 控制 台 并 显示 。 代 码 如 下 : 
Re ae 


01 using System; 

02 using System.Collections.Generic; 
03 using System. Ling; 

04 using System. Text; 

05 namespace cha2 2 


06 ( 
07 class Program 
08 { 
09 Static void Маїп (string[] args) 
10 { 
п char cl ='С'; 
12 dar c2 =" '; 
13 Console. Writeline (cl) ; 
14 Ccnsole.Writeline (c2); 
15 } 
16 } 
£e 
其 中 ， 


第 11 行 声明 了 一 个 字符 类 型 变量 ,并 赋值 一 个 英文 字母 。 字 符 类 型 的 赋值 需要 将 所 赋 
值 (C ) 放 在 单 引 号 。 

第 12 行 声明 了 一 个 字符 类 型 变量 ,并 赋值 一 个 中 文 汉字 ,相同 的 ,所 赋值 ( 字 ) 需 要 放 
在 单 引号 中 。 与 其 他 语言 不 同 ,C# 中 的 : E ORERE 个 字符 ,如 中 文 汉字 。 

第 13.14 行将 两 个 : ee 量 输出 到 控制 台 

第 4 步 ， 编 译 并 运行 代码 , 运 结果 如 图 2.25 所 示 


с^ С: MWINDOWSAsysten32Vcnd. exe 


图 2-25 ”字符 类 型 的 应 用 


字符 类 型 (char) 表示 一 个 字符 ,占用 2 个 字 节 。 

第 5 步 ” 新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_3。 在 入 口 函 数 Main( ) 中 添加 代码 : 
首先 声明 布尔 类 型 变量 b, 并 赋值 ;然后 使 用 控制 台 类 Console 把 变量 b. 的 值 输出 到 控制 台 
并 显示 。 代 码 如 下 : 


01 using System; 

02 using System.Collections.Generic; 
03 using System.Ling; 

04 using System. Text; 

05 namespace cha2 3 

06 { 


07 class Program 


08 { 
09 static void Main(string[] args) 
10 { 
11 bool b=true; // 声 明 一 个 布尔 类 型 的 变量 
12 Ccnsole.Writeline (b); // 输 出 到 控制 台 
13 
14 ) 
15) 
其 中 : 


第 11 行 声明 布尔 类 型 的 变量 使 用 关键 字 Боо! , 其 值 只 有 两 个 : true 和 false, 
第 12 行将 布尔 类 型 变量 输出 到 控制 台 。 
第 6 步 ” 编译 并 运行 代码 ,运行 结果 如 图 2-26 所 示 


сх С: WINDOWS Asysten32Vcnd. exe [-]5]5] 


图 2-26 布尔 类 型 的 应 用 


第 7 步 ” 新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_4。 首 先 创建 Student 结构 体 ， 人 ] 
函数 Main ( ) 中 添加 代码 ,创建 一 个 Student 结构 对 象 ,并 设置 其 属性 值 ,使 用 控制 台 
Console 把 属性 值 输出 到 控制 台中 并 显示 。 代 码 如 下 : 

01 using System; 

02 using System.Collections.Generic; 

03 using System. Ling; 


06 ( 

07 class Program 

08 { 

09 static void Main (string[] args) 

10 { 

п Student stu =new Student () ; // 创 建 一 个 结构 对 象 
12 // 设 置 对象 的 属性 ,学 号 .姓名 .成 绩 

13 stu.1d=201405001; // 学 号 

14 stu.Neme =: Й"; // 姓 名 

15 stu.Score -90; // 成 绩 

16 // 和 输出 到 控制 台中 ,并 显示 出 来 

17 Console.Writeline (stu.1d) ; /输出 学 号 
18 Console.WriteLine (stu.Name) ; // 输 出 姓名 
19 Console.Writeline(stu.Score); ГИН Л 
20 ) 


21 ] 

23 /// < sumary> 

24 /// 学 生 信息 结构 
25 /// < /smmary > 

26 public struct Student 


27 { 

28 public long Id; // 学 号 
29 Public string Name; // 姓 名 
30 public double Score; // 成 绩 
a ) 

32 } 


第 11 行使 用 new 关键 字 创 建 了 一 个 结构 实例 

第 13 -15 行 设置 对 象 的 属性 值 , 这 些 属性 包括 学 号 .姓名 、 分 数 

第 17 ~ 19 行将 3 个 属性 值 输出 到 控制 台 

第 26 ~31 行使 用 关键 字 struct 创建 Student 结构 ,并 设置 Id , Name „Score 三 个 属性 。 
第 28 行 long 表示 长 整数 类 型 ,是 64 位 有 符号 整数 。 

第 29 17 string 表示 字符 串 类 型 ,将 多 个 字符 组 合 在 一 起 ,以 “\0’ 结尾 

第 30 17 double 表示 双 精 度 整数 类 型 ,通常 用 于 定义 小 数 ， 

第 8 步 ” 编 译 并 执行 代码 ,运行 效果 如 图 2-27 所 示 


<\ C: WINDOWS Asystem32Vcnd. ехе 


图 2-27 结构 类 型 的 应 用 


知识 链接 : 结构 占用 栈 内 存 , 对 其 操作 的 效率 要 比 类 高 ,在 使 用 完 后 能 够 自动 释放 内 存 
分 配 且 容易 复制 ,只 需要 使 用 等 号 就 可 以 把 一 个 结构 赋值 给 另 一 个 结构 。 

第 9 步 ” 新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2 5。 首先 创建 Student 结构 体 ,在 入 口 
函数 Main ( ) 中 添加 代码 ,创建 一 个 Student 结构 对 象 ,并 设置 其 属性 值 ,使 用 控制 台 类 
Console 把 属性 值 输出 到 控制 台中 并 显示 。 代 码 如 下 : 

01 using System; 

02 using System.Collections.Generic; 

03 using System.Ling; 

04 using System. Text; 

05 namespace cha2 5 


06 ( 

07 class Program 

08 { 

09 static void Main (string[] args) 


«39. 


п // 声 明 一 个 变量 i, 并 通过 Readrine() 获 取 用 户 输入 的 信息 
12 int i -int.Parse (Console.ReadLine ()) ; 
13 // 条 件 分 支 语句 
14 switch (i) 
15 t 
16 сазе (int)enumWeek.Monday: // 返 回 1 
17 Ccnsole.Writeline ("FF th ЕЛЖ"); 
18 break; 
19 case (int)enumieek.Wedensday : // 返 回 3 
20 Console WriteLine "HHA"; 
21 break; 
22 case (int)enuniieek. Saturday : // 返 回 6 
23 Ccnsole.Writeline ("好 好 睡觉 "); 
24 break; 
25 default: 
26 break; 
21 ) 
28 ) 
29 ) 
30 /// <sumary> 
зі /// 星 期 枚 举 
32 /// </sumary> 
33 public enum ennWeek 
34 { 
35 Morcay =1, 
36 Tuesday 2, 
37 Wedensday 3, 
38 Thursday =4, 
39 Friday 5, 
40 Saturday 6, 
a Sunday =7 
42 ) 
43) 
其 中 : 


第 12 行使 用 int. Parse( ) 让 字符 串 类 型 转换 成 整数 类 型 。 

第 13 ~21 {7 switch 是 一 个 条 件 分 支 语 句 , 每 个 分 支 使 用 case 关键 字 来 判断 是 否 符合 条 
件 ,符合 则 会 执行 相应 的 语句 块 。break 是 跳 转 语句 ,执行 完 对 应 的 语句 后 , 则 会 跳出 该 条 件 
分 支 语句 ,并 停止 执行 。 

第 33 行使 用 enum 关键 字 创建 一 个 枚 举 类 型 。 

第 10 步 ”编译 并 执行 代码 ,在 控制 台中 输入 不 同 的 编码 ,会 显示 不 同 的 提示 信息 ,比如 
输入 6, 提示 “好 好 睡觉 ” ,运行 效果 如 图 2-28 所 示 。 

第 11 步 ”新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_6。 在 入 口 函 数 Main () 中 添加 代 

. 40 . 


fij. 


ex С: AWINDOWSAsysten32lcnd. ехе [-|S[x] 


2-28 枚 举 类 型 的 应 用 


首先 创建 两 个 字符 串 类 型 变量 strl 和 str2 ,并 赋值 ;然后 使 用 控制 台 类 Console 把 变量 
strl 和 str2 的 值 输出 到 控制 台 - - 。 代码 如 下 : 

01 using System; 

02 using System.Collecticns.Generic; 

03 using System. Ling; 


04 using System. Text; 
05 namespace cha2 6 


06 ( 
07 class Program 
08 { 
09 Static void Main (string[] args) 
10 { 
11 string strl -"Hello World"; 
12 string str2 = 北京 欢迎 你 所 
13 Gcnsole.WriteLine (511); 
14 Gonsole.WriteLine (st12) ; 
15 ] 
16 } 
17 } 

其 中 : 


第 11 和 12 行 创建 了 两 个 字符 串 类 型 的 变量 strl 和 su2 ,所 赋值 放 在 “" …""” 中 将 多 个 


字符 组 合 在 一 起 ,以 “\0” 结 尾 。 字 符 串 可 以 由 英文 .中文 组 成 ,也 可 包含 空格 


码 : 


B 13 和 14 行将 字符 串 类 型 变量 输出 到 控制 台 
第 12 步 ”编译 并 执行 代码 ,运行 效果 如 图 2-29 所 示 


Ж 


** С: AWINDOWSVAsysten32lcnmd. exe 


图 2-29 字符 串 的 应 用 


第 13 步 ”新 建 一 个 控制 台 应 用 程序 , 命 命名 为 ; cha2_7。 在 入 口 函 数 ea 


首先 创建 一 个 整数 的 数组 ; 然后 使 用 控制 台 类 Console 将 数组 输出 到 控制 台 并 显示 。 代 


E 


人 码 如 下 : 


01 using System; 

02 using System.Collections.Generic; 
03 using System. Ling; 

04 using System. Text; 

05 namespace cha2 7 


06 ( 
07 class Program 
08 ( 
09 static void Main (string[] args) 
10 { 
п // 创 建 一 个 数组 ,并 初始 化 ,添加 6 个 整形 元 素 到 数组 中 
12 int[] myArray={0, 1, 2, 3, 4, 5 ); 
13 // 获 取 数 组 中 索引 为 3 的 数值 ,并 输出 到 控制 台中 
14 Ccnsole.Write (" 激 组 中 的 第 3 个 索引 值 为 : m; 
15 Console.WriteLine (myArray [3]) ; 
16 // 获 取 数 组 的 总 长 度 
17 Ccnsole.Write ("Н B b I BE у: "); 
18 Console.Writeline (myArray .GetLength (0) ) ; 
19 ) 
20 ) 
21) 
Жр; 


第 12 行使 用 int[ ] 定 义 了 一 个 整数 类 型 的 数组 ,数组 的 赋值 使 用 大 括号 表示 ,不 同 的 索 
引 值 使 用 逗号 分 隔 

第 15 行 myArray[3] 使 用 中 括号 中 的 索引 值 来 获取 对 应 的 数据 ,数组 的 索引 值 是 从 0 
开始 的 。 

第 18 行 GetLength( ) 方 法 可 以 获取 数组 的 长 度 ,其 中 参数 表示 数组 的 维度 ,myArray 数 
组 为 一 维 数组 ,所 以 参数 是 0 

第 14 步 ”编译 并 执行 代码 ,运行 效果 如 图 2-30 所 示 。 


°x C:\¥INDOYS\systen32\cnd. ехе 


图 2-30 数组 的 应 用 


由 于 数组 的 索引 值 是 从 0 开始 的 ,所 以 myAray[3] 输 出 的 值 为 Зы 
【任务 小 结 】 
本 任务 介绍 C# 语 言 中 的 数据 类 型 以 及 数据 类 型 之 间 的 关系 ,重点 介绍 常用 数据 类 型 的 
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应 用 。 使 用 数据 类 型 对 数据 进行 分 类 ,方便 地 组 织 数据 ,数据 与 数据 之 间 就 可 以 进行 比较 复 


杂 的 运算 和 处 理 , 掌 握 数据 类 型 的 应 用 至 关 重 要 。 


【拓展 提高 】 
1. 隐 式 类 型 转换 


第 1 步 ”新 建 一 个 控制 台 ршн. cha2 8。 在 入 口 函 数 Main( ) 中 添加 代码 : 
ae 一 个 double 类 型 变量 数组 ;然后 将 两 个 整数 类 型 变量 的 和 


赋值 给 double 类 型 ; наас 类 Console 将 double 类 型 的 值 输出 到 控制 台 


代码 如 下 : 


01 using System; 

02 using System.Collecticons.Generic; 
03 using System. Ling; 

04 using System. Text; 

05 namespace cha2 8 


06 ( 

07 class Program 

08 { 

09 static void Main(string[] args) 
10 { 

11 inti-5; 

12 int j-8; 

13 double d; 

14 //int 类 型 隐 式 转换 为 double 类 型 
15 d=i j; 

16 Console.WriteLine (d) ; 

17 ) 

18 ) 

19) 


第 11 和 12 行 声明 了 两 个 整数 类 型 变量 并 赋值 。 
第 13 行 声 明 一 个 double 类 型 变量 。 


了 并 显示 。 


第 15 行将 两 个 整数 类 型 变量 的 和 赋值 给 double 类 型 变量 ,实现 隐 式 类 型 转换 


第 16 行将 d 变量 的 值 输出 。 
第 2 步 ” 编译 并 执行 代码 ,运行 效果 如 图 2-31 所 示 。 


с^ C: MWINDOWSAsystem32Xcnd. ехе 


Kd2-31 隐 式 类 型 转换 


在 C# 中 ,只 有 有 具有 相同 数据 类 型 的 对 象 才能 够 互相 操作 。 很 多 时 候 ,为 了 进 


行 不 同类 
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型 数据 的 运算 ,需要 把 数据 从 一 种 类 型 转换 为 另 一 种 类 型 , 即 进行 类 型 转换 。C# 中 有 下 面 


两 种 转换 方式 。 


(1) 隐 式 转换 : 无 须 指 明 转 换 , 编 译 器 自动 将 操作 数 转 换 为 相同 的 类 型 (本 例 ) 。 

(2) 显示 转换 : 需 指 定 把 一 个 数据 转换 成 其 他 类 型 (下 一 个 示例 ) 。 

当 两 个 不 同类 型 的 操作 数 进行 运算 时 ,编译 器 会 试图 对 其 进行 自动 转换 ,使 两 者 变 为 同 
一 类 型 。C# 支 持 的 隐 式 类 型 转换 如 表 2-4 所 示 。 


R24 C# 支 持 的 隐 式 类 型 转换 


源 类 型 目的 类 型 

sbyte short „int „long „float „double „decimal 

byte short ,ushort „int „uint „ulong „float , double ,decimal 
short int „long „float „double „decimal 

ushort int „uint „long „ulong „float ‚double „decimal 

int long „float „double „decimal 

uint long „ulong „float „decimal 

long „ulong float „double „decimal 

float double 

char ushort , int „uint „long „ulong „float „double , decimal 


不 同 的 数据 类 型 具有 不 同 的 存储 空间 ,如果 试 图 将 一 个 需要 较 大 存储 空间 的 数据 ,转换 
为 存储 空间 较 小 的 数据 ,就 会 出 现 错误 。 如 将 步骤 1 中 的 代码 进行 修改 , 先 定义 两 个 double 
类 型 ,再 定义 一 个 int 类 型 ,将 double 类 型 转换 为 int 类 型 ,如 图 2-32 所 示 。 


Eusing System; 


1 

2 |using Systenm.Collections.Generic; 
3 |using System. Linq; 

4 [using System. Text; 

5 

6 Emnamespace cha2 8 

T 

зв class Program 

9 

10 E static void Main(string[] args) 
11 

12 double i = 5; 

13 double j = 8; 

14 int d; 

15 /Ydouble 转 换 为 int 

16 d-ziti 

17 Console. VriteLine (d): 
18 H 

19 H 

20 |]! 

21 


图 2-32 ”错误 的 隐 式 类 型 转换 


编译 代码 ,报错 ,如 图 2-33 所 示 。 
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O: 个 错误 | No 1 [00 个 消息 


| 说明 w = ЕГО ДИНИНЕ 7 文件 a fa » < 项 目 
O1 无 法 格 类 型 “double” 隐 式 转换 为 “int”。 存 在 一 个 显 式 转换 (是 天 缺少 强制 转换 ?] Progran. cs 16 17 cha2_8 


图 2-33 ” 隐 式 类 型 转换 报错 


2. 显示 类 型 转换 

第 1 步 ”新建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_9。 在 入 口 函 数 Main( ) 中 添加 代码 : 
首先 创建 两 个 整数 类 型 的 变量 ,一 个 double 类 型 变量 数组 ;然后 将 两 个 整数 类 型 变量 的 和 
赋值 给 double 类 型 ;最 后 使 用 控制 台 类 Console 将 double 类 型 的 值 输出 到 控制 台 并 显示 。 
代码 如 下 : 

01 using System; 

02 using System.Collections.Generic; 

03 using System. Ling; 

04 using System. Text; 

05 namespace cha2 9 


06 ( 
07 Class Program 
08 { 
09 static void Main (string[] args) 
10 { 
п // 提 示 用 户 输入 半径 
12 Console WriteLine ("请 输入 半径 : ") ; 
13 // 将 用 户 输入 的 字符 串 转换 为 decimal 类 型 
14 decimal г -decimal .Parse (Console.ReadLire ()) ; 
15 // 计 算 圆 形 的 面积 
16 decimal area -(decimal)Msth.PI * г * r; 
17 Console .WriteLine(" 圆 形 的 面积 为 : " 4Meth.Found (area, 4) .ToString()); 
18 ) 
19 ) 
20) 
А; 


第 14 行使 用 decimal 类 型 的 Parse( ) 方 法 ,将 用 户 输入 的 字符 串 显示 转换 为 decimal 类 型 。 

第 16 行将 圆周 率 ( Math. PT) 的 类 型 long 显示 转换 为 decimal 类 型 ,并 计算 圆 面积 。 

第 17 行 Math. Round( ) 方 法 可 以 使 用 四 舍 五 人 的 方式 返回 指定 的 小 数位 数 ,这 里 取 4 
位 小 数 。 使 用 ToString( ) 方 法 ,把 计算 结果 显示 转换 为 一 个 字符 串 。 

第 2 步 编译 并 执行 代码 ,运行 效果 如 图 2-34 所 示 。 

显示 类 型 转换 ,又 叫做 强制 类 型 转换 。 在 有 些 情况 下 , 若 将 不 能 隐 式 类 型 转换 的 数据 类 
型 进行 数据 转换 ,就 需要 进行 显示 类 型 转换 。 在 示例 中 使 用 了 3 种 显示 转换 方法 。 

(1) 把 所 要 转换 的 目的 数据 类 型 放 在 圆 括 号 内 ,例如 decimal area = ( decimal ) Math. 
PI * r * r. 

(2) 使 用 Parse( ) 方 法 ,例如 decimal r = decimal. Parse( Console. ReadLine( ) ) > 
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图 2-34 ”显示 类 型 转换 


(3) 使 用 System. Convert 类 中 的 类 型 转换 方法 ,例如 Math. Round(area, 4). ToString( ) „ 

3. 装 箱 和 拆 箱 

第 1 步 ”新 建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_10。 在 入 口 函 数 Main C) 中 添加 代 
码 : 首先 声明 一 个 整数 类 型 的 变量 i, 将 其 值 输出 ;然后 把 i 装 箱 成 obj ,输出 obj; 最 后 再 把 
obj 拆 箱 成 变量 i。 代 码 如 下 : 

01 using System; 

02 using System.Collecticns.Generic; 

03 using System.Ling; 

04 using System. Text; 

05 namespace cha2 10 


06 ( 
07 class Program 
08 ( 
09 static void Main (string[] args) 
10 { 
п int 1=50; 
12 Console.WriteLine (i); 
13 // 装 箱 
14 Cbject œj =i; 
15 Console.WriteLine (d5j) ; 
16 dj =60; 
17 // 拆 箱 
18 i-(nt)dyj; 
19: Console.Writeline (i); 
20 } 
21 } 
22) 
Hop. 
第 14 行将 i 装 箱 成 obj。 
第 18 行将 obj 拆 箱 成 i。 


第 2 步 ” 编 译 并 执行 代码 ,运行 效果 如 图 2-35 所 示 。 
隐 式 和 显示 类 型 转换 属于 不 同 值 类 型 之 间 的 转换 , 装 箱 和 拆 箱 是 值 类 型 和 引用 类 型 之 
间 的 转换 。 
确切 地 说 , 装 箱 和 拆 箱 的 过 程 是 值 类 型 与 Object 类 型 之 间 的 转换 。 装 箱 是 把 值 类 型 转 
换 为 Object 类 型 ,而 拆 箱 则 相反 ,把 Object 类 型 转换 为 值 类 型 。 其 中 ,Object 类 型 是 一 个 内 
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图 2-35 EZ HIER 
置 类 型 ,是 所 有 类 型 的 基 类 型 ,是 一 个 不 确定 类 型 。 
任务 2-3 掌握 C# 中 标识 符 与 注释 
【任务 描述 】 
小 王 是 个 新 手 , 当 他 把 代码 给 别人 看 时 ,别人 都 会 嘲笑 他 的 代码 ,因为 它 的 代码 中 命名 
奇怪 ,没有 规律 ,而且 通 篇 都 没有 注释 ,理解 代码 不 方便 


【任务 目的 】 
掌握 C#i 语 言 标识 符 的 命名 规则 ， 
掌握 C# 的 注释 的 写法 与 使 用 。 


【任务 分 析 】 
好 的 标识 符 命名 ,合理 规范 的 注释 使 得 程序 更 加 清晰 、 易 读 易 懂 。 
【基础 知识 


小 提示 : 本 部 分 内 容 在 初学 时 ,感觉 用 途 不 大 ,实际 在 企业 开发 中 ,是 十 分 重要 的 ,希望 
读者 养 成 良好 的 编程 习惯 ， 

1. 标识 各 

标识 符 是 一 种 字符 串 ,是 程序 员 对 程序 中 各 种 元 素 的 唯一 性 标识 ,通常 用 户 在 程序 中 命 
名 如 变量 方法 .参数 等 内 容 。 

Visual C# 的 标识 符 必须 遵循 下 列 语法 规则 : 

(1) 只 能 使 用 字母 数字 和 下 面 线 组 成 。 

(2) 必须 以 字母 下划线 或 @ 开始 。 

(3) Visual C# 的 标识 符 是 大 小 写 敏感 的 。 

(4) 标识 符 不 能 使 用 C# 中 预定 义 的 关键 字 名 ,但 以 @ 符号 开头 的 标识 符 , 允许 使 用 关 
键 字 作为 标识 符 。 

(5) 标识 符 不 可 与 Visual C# 中 的 类 库 名 相同 。 

一 般 情况 下 ,变量 名 首 字 母 小 写 ,后 面 各 单词 首 字母 大 写 ;而 常量 名 类 名 方法 名 、 属 性 
名 等 首 字母 大 写 , 表 2-5 中 总 结 并 描述 了 建议 使 用 的 大 小 写 约定 。 

虽然 这 是 建议 的 指导 方针 ,但 很 多 组 织 使 用 其 他 约定 ,尤其 是 在 成 员 字段 的 命名 方面 ， 
有 两 个 公共 约定 如 下 : 

(1) 字段 名 称 以 下 划 线 开头 : _highTemp 、lowTemp。 

(2) 字段 名 以 m_ 开 头 : m highTemp,m lowTemp. 

这 两 种 方法 都 有 优势 ,能 立刻 显示 这 些 标识 符 是 字段 名 称 。 
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表 2-5 ”推荐 的 标识 符 命名 风格 


风格 名 称 dü Ж 使 用 建议 示 例 
Pascal 式 | 标识 符 中 每 个 单词 都 首 字符 大 写 用 于 类 型 名 和 成 员 名 CarDeck 
Camelot | a LUE IRIREPPBUR | race gt | totalCyeleCount 
全 大 写 标识 符 由 全 大 写字 母 组 成 仅 用 于 缩写 词 10,MDA 
2. 关键 字 
关键 字 是 用 来 定义 C# 语 言 的 字符 串 记号 。 表 2-6 列 出 了 完整 的 C# 关 键 字 表 。 
R26 CHAF 
abstract as base bool break byte case 
catch char checked class const continue decimal 
default delegate do double else enum event 
explicit extern false finally fixed float for 
foreach goto if implicit in int interface 
internal is lock long namespace new null 
Object operator out override params private protected 
public readonly ref return sbyte sealed short 
sizeof stackalloc static string struct switch this 
throw true try typeof uint ulong unchecked 
unsafe ushort using virtual void volatile while 
关于 关键 字 , 要 了 解 : 


(1) 关键 字 不 能 被 用 作 变 量 名 或 任何 其 他 形式 的 标识 符 ,除非 以 @ 字 符 开始 。 

(2) 所 有 C# 关 键 字 全 部 都 由 小 写字 母 组 成 ,但 是 . NET 类 型 名 使 用 Pacal 大 小 写 约定 。 

上 下 文 关键 字 是 仅 在 特定 的 语言 结构 中 充当 关键 字 的 标识 符 , 用 于 提供 代码 中 的 特定 
含义 ,但 它 不 是 Cit 中 的 保留 字 。 二 者 的 区 别 是 ,关键 字 不 能 被 用 作 标 识 符 ,而 上 下 文 关 键 字 
可 以 在 其 他 部 分 代码 中 被 用 作 标 识 符 。 某 些 上 下 文 关键 字 ( 如 partial 和 where) 在 两 个 或 更 
多 个 上 下 文中 具有 特殊 含义 。 表 2-7 列 出 了 C# 的 上 下 文 关键 字 。 


表 2-7 C# 的 上 下 文 关 键 字 


add ascending by yield await descending 
dynamic equals from get global group 

into join let orderby partial remove 
select set value var where where 
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3. 注释 

为 了 使 程序 易 读 ,通常 要 为 程序 添加 注释 , 即 对 程序 模块 .语句 或 命令 做 文字 注释 。 运 
行 时 ,这 些 文字 不 会 作为 命令 的 一 部 分 而 被 执行 ,因而 不 会 影响 原来 的 程序 。 有 时 ,在 调试 
的 过 程 中 ,也 可 以 用 注释 的 方法 对 部 分 命令 做 暂时 的 “删除 ” ,以 缩小 调试 范围 , 待 调试 结束 
后 再 去 掉 注 释 符 。 

FEGA 的 单个 使 用 表示 所 在 行 的 该 符号 之 后 的 内 容 为 注释 ,为 单行 注释 符 , 单 行 注 
释 的 形式 如 下 : 

АТН > 

组 合 符号 “/* "与 **/” 的 成 对 使 用 表示 它们 之 间 的 内 容 为 注释 ,为 多 行 注释 符 ,多 行 
注释 的 形式 如 下 : 


/* < 注释 内 容 >* / 


【任务 实施 】 

第 1 步 ”新建 一 个 控制 台 应 用 程序 ,命名 为 : cha2_1。 

第 2 步 在 入 口 函 数 Main( ) 中 添加 代码 。 首 先 定义 两 个 不 同类 型 的 变量 i 和 sl ,给 这 
两 个 变量 赋值 ,使 用 控制 台 类 Console 把 变量 的 值 输出 到 控制 台中 并 显示 。 代 码 如 下 : 


01 namespace cha2 1 


0 { 
03 class Program 
04 { 
05 static void Main(string[] args) 
06 { 
07 int і =500; 
08 string s1 ="Hello World"; 
09 Console.Writeline (i); 
10 Ccnsole.WriteLine (sl); 
11 } 
12 ) 
13] 
其 中 : 


第 7 行 定 义 一 个 int 型 的 变量 i, 并 赋值 500. 

第 8 行 定 义 一 个 sting 型 的 变量 sl ,并 赋值 “Hello World”。 在 给 字符 串 类 型 的 变量 赋值 
时 ,需要 使 用 双 引 号 把 字符 串 括 起 来 。 

第 9 ~ 10 行 分 别 对 变量 1 和 sl 输出 。 

第 3 步 ” 编 译 并 执行 代码 ,运行 结果 如 图 2-36 所 示 。 

第 4 步 对 第 2 步 的 代码 在 编辑 器 框架 中 编辑 如 下 代码 : 

01 using System 

02 using System.Collections.Generic; 

03 using System. Ling; 
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C:\¥INDOYS\systen32\cad. ехе [-Iclx| 


图 2-36 输出 整数 类 型 .字符 串 类 型 变量 


04 using System. Text; 

05 ///////////////////////////////// 

06 // 本 例 用 来 说 明 注释 符 的 使 用 // 
07 //////////////////////////////// 

08 namespace cha2 1 


09 ( 
10 class Program 
1 ( 
12 static void Main (string[] args) 
13 ( 
4 // 声 明 变 量 , 并 给 变量 赋值 
5 int i =500; // 声 明 变 量 i 
16 string sl -"Hello World"; /* 声明 变量 sl * / 
7 /* 输出 变量 到 控制 台中 * / 
18 Ccnsole.Writeline (i); // 输 出 变量 i 
9 Console.WriteLine (51); /* 输出 变量 siu / 
20 ) 
21 ) 
22) 
Jü; 


第 5 ~7 行 是 对 程序 的 代码 段 说 明 。 

第 14 .15 和 18 行使 用 “//” 方 式 对 代码 进行 注释 。 

第 16、17 和 19 行使 用 */* ee * /人 "方式 对 代码 进行 注释 。 

第 5 步 Сш + F5 键 或 者 选择 “调试 "| “开始 执行 (不 调试 ) 菜单 命令 (如 图 2-6 所 
ZR) ,编译 并 执行 代码 ,运行 效果 如 图 2-25 所 示 ,与 图 2-24 相同 ,显示 注释 在 代码 执行 中 不 
起 作用 ,只 是 为 了 使 代码 更 加 清晰 。 

【任务 小 结 】 

本 任务 介绍 了 标识 符 以 及 注释 的 命名 规范 和 使 用 方法 ,恰当 的 标识 符 .适当 的 注释 , 增 
强 系统 的 可 读 性 ,便于 查 错 、 修 改 。 


四 、 项 目 小 结 
本 项 目 通 过 3 个 任务 介绍 了 C# 语 言 中 的 核心 内 容 ,通过 本 项 目的 讲解 ,读者 已 经 具有 


学 习 ASP .NET 的 技术 基础 了 。 如 果 读 者 还 想 深入 学 习 C# 语 言 ,请 参考 相关 技术 书籍 。 
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五 、 项 目 考核 


1. 填空 题 

(1) 标识 符 是 一 种 字符 串 ,是 程序 员 对 程序 中 各 种 元 素 的 唯一 性 标识 ,通常 用 户 在 程序 
中 命名 如 等 内 容 。 

(2) 为 了 使 程序 易 读 ,通常 要 为 程序 添加 注释 , 即 对 或 做 文字 注释 。 

(3) C# 是 Visual Studio 开发 工具 中 的 程序 设计 语言 之 一 , 既 可 以 用 来 编写 基于 通用 网 
络 协议 的 ,也 可 以 编写 各 种 和 Windows 窗口 界面 程序 。 

(4) 编写 的 AP. NET 应 用 程序 通常 包括 和 这 两 部 分 的 代码 。 

(5) C# 主 要 用 于 开发 和 这 3 种 经 典 的 应 用 程序 。 

(6) C# 语 言 的 数据 类 型 主要 分 为 两 类 : 和 Б 

(7) 从 计算 机 的 角度 来 看 ,简单 类 型 可 分 为 N EATER 、 

(8) 型 是 整 型 类 型 中 最 长 的 ,其 次 是 int 型 ,最 短 的 则 是 类 型 。 

(9) 枚 举 类 型 是 一 种 独特 的 ,用 于 声明 一 组 命名 的 常数 , 即 系统 把 3 

的 一 组 数据 作为 一 个 集合 放 到 一 起 形成 一 个 新 的 数据 类 型 。 

2. 简 答题 

(1) C# 标 识 符 必须 遵循 的 语法 规则 是 什么 ? 

(2) 代码 间 注 释 规范 是 什么 ? 

(3) CH# 语 言 的 优势 是 什么 ? 

(4) 新 建 项 目 中 系统 自动 添加 的 Properties 有 什么 作用 ? 

(5) 引用 类 型 的 分 类 有 哪些 ? 

(6) 如 何 声明 数组 ? 

3. 上 机 操作 题 

(1) 创建 一 个 应 用 程序 ,使 用 恰当 的 标识 符 和 添加 适当 的 注释 。 

(2) 创建 一 个 名 称 和 解决 方案 的 名 称 为 “testWeb” 的 Web 应 用 程序 。 

(3) 创建 一 个 9 个 整形 元 素 的 数组 ,实现 索引 值 4 和 5 的 加 法 运算 。 
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项 目 3 内 置 对 象 
一 、 引 言 


内 置 对 象 提供 接收 通过 浏览 器 请 求 发 送 的 信息 响应 浏览 器 以 及 存储 用 户 信息 的 功能 ， 
以 实现 其 他 特定 的 状态 管理 和 页 面 信息 传递 。 


二 、 项 目 要 点 


掌握 内 置 对 象 的 常用 方法 和 属性 。 
掌握 主要 内 置 对 象 的 区 别 。 


=, 任务 


任务 3-1 获取 客户 端 信息 

【任务 描述 】 

小 王 开发 应 用 程序 ,需要 根据 用 户 的 信息 提供 个 性 化 服务 ,他 需要 获取 尽 可 能 多 的 客户 
端 信息 ,在 ASP .NET 中 ,可 以 使 用 Page 对 象 获取 客户 端 信息 。 

【任务 目的 】 

熟悉 内 置 对 象 的 基本 用 法 。 

掌握 通过 Page 对 象 获取 和 设置 页 面 信息 。 

掌握 Page 对 象 的 常用 事件 如 Init 事件 .Load 事件 的 意义 和 用 法 。 

【任务 分 析 】 

Page 对 象 很 像 一 个 调度 者 ,完成 响应 HS 的 HTTP 请 求 , 并 初始 化 一 些 内 部 对 象 ;初始 
化 页 面 上 的 各 种 控件 ,恢复 ViewState 状态 , 载 和 页面 ,生成 页 面 HTML 代码 等 流水 线 式 的 
工作 。 

Page 对 象 参 与 了 Web 页 面 从 生成 到 消亡 的 各 阶段 ,所 以 通过 Page 对 象 的 学 习 , 掌握 
Web 页 面 各 阶段 执行 的 方法 、 使 用 的 消息 、 保 持 的 数据 .呈现 的 状态 等 ,会 对 理解 和 分 析 程 
序 设 计 中 出 现 的 问题 有 很 大 的 帮助 。 

在 服务 器 端 获取 远程 客户 端的 IP. 地 址 和 当前 网 页 的 标题 (Title) ,在 页 面 加 载 时 显示 在 
页 面 中 ,并 判断 当前 页 面 是 首次 加 载 还 是 响应 客户 端 回 发 而 加 载 ,并 在 页 面 加 载 时 显示 在 页 
面 中 。 

【基础 知识 】 

Page 对 象 是 由 System. Web. UI 命名 空间 中 的 Page 类 来 实现 的 ,Page 类 与 扩展 名 为 
.aspx 的 文件 相关 联 ,这 些 文件 在 运行 时 被 编译 为 Page 对 象 , 并 缓存 在 服务 器 内 存 中 。Page 
对 象 提 供 的 常用 属性 方法 及 事件 如 表 3-1 所 示 。 
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表 3-1 Page 对象 常 用 属性 方法 及 事件 


名 Ж 功能 说 明 
IsPostBack 属性 获取 一 个 值 ,该 值 表 示 该 页 是 否 正 为 响应 客户 端 回 发 而 加 载 
IsValid 属性 获取 一 个 值 ,该 值 表示 页 面 是 否 通过 验证 
EnableViewState 属性 获取 或 设置 一 个 值 ,该 值 指示 当前 页 请 求 结束 时 是 否 保持 其 视图 状态 
Validators 属性 获取 请 求 的 页 上 包含 的 全 部 验证 控件 的 集合 
DataBind 方法 将 数据 源 绑 定 到 被 调用 的 服务 器 控件 及 其 所 有 子 控件 
FindControl 方法 在 页 面 中 搜索 指定 的 服务 器 控件 
RegisterClientScriptBlock 方法 向 页 面 发 出 客户 端 脚本 块 
Validate 方法 指示 页 面 中 所 有 验证 控件 进行 验证 
Init 事件 当 服 务 器 控件 初始 化 时 发 生 
Load 事件 当 服 务 器 控件 加 载 到 Page 对 象 中 时 发 生 
Unload 事件 当 服 务 器 控件 从 内 存 中 种 载 时 发 生 


1. IsPostBack 属性 
IsPostBack 属性 用 来 获取 一 个 布尔 值 ,如 果 该 值 为 True, 则 表示 当前 页 是 为 响应 客户 端 
回 发 (例如 单 击 按钮 ) 而 加 载 ,否则 表示 当前 页 是 首次 加 载 和 访问 。 

小 提示 : 很 多 网 页 都 会 使 用 到 这 个 属性 。 
例如 在 页 面 首次 加 载 时 进行 一 些 操作 。 代 码 如 下 : 
void Page Load (Object o, EventArgs е) 
t 

if (!IsPostBack) 

t 

// 如 果 页 面 为 首次 加 载 , 则 进行 一 些 操作 


// 如 果 不 是 首次 加 载 响应 客户 端 回 发 ), 则 进行 另外 一 些 操作 


) 


2. IsValid 属性 

IsValid 属性 用 来 获取 一 个 布尔 值 ,该 值 指示 页 验证 是 否 成 功 ,如 果 页 验证 成 功 , 则 为 
true; 否则 为 false。 一 般 在 包含 有 验证 服务 器 控件 的 页 面 中 使 用 ,只 有 在 所 有 验证 服务 器 控 
件 都 验证 成 功 时 ,IsValid 属性 的 值 才 为 trues 

例如 使 用 IsValid 属性 来 设置 条 件 语句 ,输出 相应 的 信息 。 


void Button Click (Cbject Sender, EventArgs E) 
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if (Eage.ISValid ==true) — // 也 可 写成 if (Page.IsValid) 
{ 
mylabel .Text "您 输入 的 信息 通过 验证 '"; 
} 
else 
{ 
mylabel .Text =" 您 的 输入 有 误 ,请 检查 后 重新 输入 !"; 
} 
} 


3. RegisterClientScriptBlock 方法 

RegisterClientScriptBlock 方法 用 来 在 页 面 中 发 出 客户 端 脚本 块 , 它 的 定义 如 下 : 

Piblic virtual void RegisterClientScriptBlock (string key, string script); 

其 中 参数 key 为 标识 脚本 块 的 唯一 键 ,script 为 发 送 到 客户 端的 脚本 的 内 容 , 客 户 端 脚本 刚 
好 在 Page 对 象 的 < form runat = server > 元 素 的 开始 标记 后 发 出 。 脚 本 块 是 在 呈现 输出 的 
对 象 被 定义 时 发 出 的 ,因此 必须 同时 包括 < script > 和 «script > 两 个 标记 。 通 过 使 用 关键 
字 标 识 脚 本 ,多 个 服务 器 控件 实例 可 以 请 求 该 脚本 块 ,而 不 用 将 其 发 送 到 输出 流 两 次 。 具 有 
相同 key 参数 值 的 任何 脚本 块 均 被 视 为 重复 的 。 另 外 最 好 在 脚本 周围 加 入 HTML 注释 标 
记 , 以 便 在 请 求 的 浏览 器 不 支持 脚本 时 脚本 不 会 呈现 。 

4. Init 事件 

页 面 生命 周期 中 的 第 一 个 阶段 是 初始 化 ,这 个 阶段 的 标志 是 mit 事件 。 在 成 功 创建 页 
面 的 控件 树 后 ,将 会 触发 Page 对 象 的 此 事件 。Init 对 应 的 事件 处 理 程序 为 Page_Init( ) 。 在 
编程 实践 中 ,Init 事件 通常 用 来 设置 网 页 或 控件 属性 的 初始 值 。 

5. Load 事件 

当 页 面 被 加 载 时 ,会 触发 Page 对 象 的 Load 事件 ,Load 对 应 的 事件 处 理 程序 为 Page_ 
Load( ) ,Load 事件 与 Init 事件 的 主要 区 别 在 于 ,对 于 来 自 浏览 器 的 请 求 而 言 ,网 页 的 Init 事 
件 只 触发 一 次 ,而 Load 事件 则 可 能 触发 多 次 。 
事实 上 ,除了 上 述 两 个 常用 事件 , 当 浏 览 器 给 ASP. МЕТ 页 面 发 送 请 求 时 ,首先 响应 的 
就 是 与 aspx 页 面相 关联 的 Page 类 对 象 ,Page 类 在 其 生命 周期 内 执行 的 方法 按 先后 顺序 的 
解释 如 下 。 

(1) OnPrelnit 方 法 (触发 PreInit 事件 ) ,在 页 面 初始 化 之 前 发 生 。ASP . NET 在 使 用 此 
方法 时 创建 了 页 面 声明 定义 的 控件 树 ,在 执行 此 方法 之 后 ,Page 类 对 象 又 会 自动 调用 控件 
树 中 所 有 控件 的 OnInit 方法 ,并 将 控件 初始 化 。 所 以 执行 此 方法 后 ,程序 已 经 能 够 访问 置 于 
页 面 的 各 种 控件 了 ,控件 的 属性 被 设置 为 aspx 源 中 所 定义 的 初始 值 。 

(2) Onmit 方法 (触发 Init 事件 ) ,在 页 面 初始 化 时 发 生 。 执 行 此 方法 后 ,页 面 会 跟踪 
ViewState 的 值 。 

(3) OnlnitComplete 方法 (触发 InitComplete 事件 ) ,页 面 初始 化 完成 时 发 生 。 如 果 
IsPostBack 为 True ,这 个 方法 执行 后 ,页 面 还 会 完成 两 项 非常 重要 的 工作 : 首先 ,将 触发 
PostBack 控件 及 其 触发 的 相关 参数 进行 解析 , 称 之 为 把 回 传 事件 映射 到 服务 器 端 事件 ,实现 
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IPostBackEventHandler 接口 ;然后 ,将 解析 出 来 的 ViewState 的 值 赋 给 相应 控件 的 相应 属性 ， 
称 之 为 加 载 回 传 数据 ,实现 IPostBackDataHandler 接口 。 

(4) OnPreLoad 方法 (触发 PreLoad 事件 ) ,页 面 加 载 人 之 前 发 生 。 

(5) OnLoad 方法 (触发 Load 事件 ) ,此 方法 开始 时 ,控件 树 中 的 所 有 控件 都 已 被 初始 
化 ,并 恢复 到 他 们 在 前 一 个 周期 的 最 后 状态 (加 载 回 传 数据 ) ,这 时 页 面 就 能 够 安全 访问 页 
面 中 的 其 他 控件 了 ,所 以 系统 提供 一 个 Page_Load 方法 ,以 便 在 此 事件 触发 时 运行 用 户 自 定 
义 的 一 些 程序 。 

(6) OnLoadComplete 方法 (触发 LoadComplete 事件 ) 。 

(7) OnPreRender 方法 (触发 PreRender 事件 ) 和 OnPreRenderComplete 方法 (出 发 
PreRenderComplete 事件 ) ,在 页 面 和 控件 的 HTML 代码 生成 之 前 所 先后 执行 的 方法 。 

(8) OnSaveStateComplete 方法 (触发 SaveStateComplete 事件 ), 保存 页 面 控件 的 
ViewState 值 。 

(9) Render 方 法 ,没有 触发 事件 ,生成 页 面 和 控件 的 HTML 代码 。 

(10) OnUnload 方法 (触发 Unload 事件 ) ,Page 类 运行 结束 时 ,将 释放 内 存 , 整 个 生命 周 
期 结束 。 
由 此 可 以 看 出 一 个 aspx 页 面 就 像 一 个 Windows 的 应 用 程序 ,从 载 入 内 存 开始 ,顺序 执 
行 一 系列 的 程序 ,生成 一 个 结果 HTML, 再 退出 内 存 。 只 是 这 个 程序 的 执行 不 是 由 双击 鼠标 
或 是 运行 命令 触动 的 ,而 是 由 IIS 根据 HTTP 请 求 来 触动 的 。 

【任务 实施 】 

第 1 步 选择 "文件 "| 新 建 " | 网 站 ”菜单 命令 ,打开 “新建 网 站 ”对话 框 ,选择 ASP 
.NET 空 网 站 ”, 单 击 “ 确 定 "按钮 ,成功 创建 一 个 空 网 站 项 目 。 

第 2 步 ”光标 停留 在 解决 方案 管理 器 中 的 当前 项 目 根 目录 上 , 右 击 , 从 弹出 的 快捷 菜单 
中 选择 “添加 新 项 "命令 ,在 弹出 的 对 话 框 中 选择 “Web 窗 体 ” , 单 击 “ 添 加 "按钮 ,成 功 添加 
一 个 名 称 为 defalut. aspx 的 ASP . NET 网 页 。 

第 3 步 打开 default. aspx, 添 加 如 下 代码 : 


< GPage Language ="С#" % > 

<script runat ="server" > 
protected void Page_Load (Gbject sender, EventArgs e) 
{ 


StringBuilder sb =пем StrirgBrilcer () ; 


if (Page.IsPostPack) 
Sb.Append ("You posted back to the page. «br >"); 


sb.)gpend ("The host address is " 4Page.Reguest .Usertost/cHress +". «br >"); 
sb.Append (“The page title is V" 4Page. Title +"\"."); 
PageMessage. Text =. ToString () ; 
} 
«/script > 
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«html > 
«head id-"Headl" runat -"server" > 
«title Page Class Exanple «/title > 
«/read > 
«body» 
«fom id -"fomil" 
runat ="зегуег" > 
«div» 
<asp:Label id -"PageMessage" 
паі -"server"/ > 
<br /><br /> 
«asp:Button id ="PagButton" 
Text =" PostBack" 
runat -"server" /> 
</div > 
</fom> 
</body> 
</html > 


第 4 步 TRES 键 或 单 击 工具 栏 上 的 “启动 调试 "按钮 ,运行 页 面 。 页 面 首次 加 载 时 ,页 
面 内 容 如 图 3-1 所 示 ; 然 后 单 击 PostBack 按钮 ,向 服务 器 提交 表单 ,引发 客户 端 回 发 ,重新 加 
载 页 面 , 此 时 Page. IsPostBack 属性 为 true ,页 面 内 容 如 图 3-2 所 示 。 

小 提示 : 掌握 Visual Stuido 2010 的 快捷 键 ,可 以 提升 开发 效率 。 


TE тулоо. E р 2 XTE Page cos ample Ш 
хен RRE SEV 收藏 夫 (A) IAM ан) 


The host address is 127.0.0.1. 
The page title is "Page Class Example". 


3-1 页 面 首 次 加 载 


【任务 小 结 】 
本 任务 介绍 了 内 置 对 象 Page ,重点 介绍 了 Page 对 象 的 常用 属性 和 事件 ,以 及 页 面 的 生 
命 周期 。 通 过 实例 熟悉 了 如 何 获取 或 设置 网 页 信息 ,网 页 的 生命 周期 和 每 个 阶段 对 应 的 事 
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i 
Юе htp//eclh. Ф 9 - E ë x || @ page Class Example 


Зең) RSO SEV ”收藏 夫 (A) IAM ”帮助 (H) 


You posted back to the page. 
The host address is 127.0.0.1. 
The page title is "Page Class Example". 


图 3-2 ”客户 端 回 发 加 载 页 面 
件 和 事件 产生 后 如 何 处 理 。 
任务 3-2 使 用 Request 对 象 求 两 数 之 和 


【任务 描述 】 

小 王 遇 到 这 样 一 个 问题 : 创建 一 个 页 面 ,让 用 户 输入 两 个 整数 ,提交 后 计算 整数 的 和 并 
返回 给 客户 端 ,并 提供 一 个 链接 列表 ,包括 搜狐 新浪 和 凤凰 网 ,用 户 单 击 列表 中 的 列表 项 可 
以 重 定向 到 相应 的 门户 网 站 。 


【任务 目的 】 
熟悉 Response 对 象 和 Request 对 象 。 
掌握 使 用 Response 对 象 和 Request 对 象 响应 用 户 请 求 的 方法 。 


【任务 分 析 】 

Request 对 象 是 从 客户 端 向 服务 器 发 出 请 求 , 包 括 用 户 提交 的 信息 以 及 客户 端的 一 些 信 
息 。 客 户 端 可 通过 HTML 表单 或 在 网 页 地 址 后 面 提供 参数 的 方法 提交 数据 ,然后 通过 
Request 对 象 的 相关 方法 来 获取 这 些 数据 。Request 的 各 种 方法 主要 用 来 处 理 客户 端 浏览 器 
提交 的 请 求 中 的 各 项 参数 和 选项 。 

Response 对 象 在 ASP 中 负责 将 信息 传递 给 用 户 。Response 对 象 用 于 动态 响应 客户 端 
请 求 , 并 将 动态 生成 的 响应 结果 返回 到 客户 端 浏 览 器 中 ,使 用 Response 对 象 可 以 直接 发 送 
信息 给 浏览 器 , 重 定向 浏览 器 到 另 一 个 URL 或 设置 cookie 的 值 等 。 Response 对 象 在 ASP 编 
程 中 非常 广泛 ,也 是 一 种 非常 好 用 的 工具 。 

Request 和 Response 对 象 是 内 置 对 象 中 最 常用 也 是 最 重要 的 ,是 服务 器 和 客户 端 之 间 
交互 的 桥梁 ,Request 和 Response 的 学 习 是 ASP . NET 编程 的 必 有 经 之 路 。 
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【基础 知识 
1. Response 对 象 
Response 对 象 是 由 类 System. Web. HttpResponse 来 实现 的 。Response 对 象 用 于 将 НТТР 
响应 数据 发 送 到 客户 端 ,告诉 浏览 器 响应 内 容 的 报头 .服务 器 端的 状态 信息 及 输出 指定 的 内 
容 。Response 对 象 常用 的 属性 及 方法 如 表 3-2 所 示 。 
表 3-2 Response 对 象 常用 属性 和 方法 


名 Ж 说 明 
BufferOutput 属性 获取 或 设置 一 个 值 ,该 值 指示 是 否 缓冲 输出 
ContentType 属性 获取 或 设置 输出 流 的 HTTP MIME 类 型 
Cookies 属性 获取 响应 Cookie 集合 
Expires 属性 获取 或 设置 该 页 在 浏览 器 上 缓存 过 期 之 前 的 分 钟 数 
IsClientConnected 属性 获取 一 个 值 ,该 值 指示 客户 端 是 否 仍 连接 在 服务 器 上 
Clear 方 法 清除 缓冲 区 中 的 所 有 内 容 输出 
Flush 方法 刷新 缓冲 区 ,向 客户 端 发 送 当前 所 有 缓冲 的 输出 
End 方法 将 当前 所 有 缓冲 的 输出 发 送 到 客户 端 ,停止 该 页 的 执行 
Redirect 方法 将 客户 端 重 定向 到 新 的 URL 
Write 方法 将 信息 写 入 HTTP 输出 内 容 流 


(1) IsValid РЕ. Мтне 方法 用 来 向 客户 端 输出 信息 。 例 如 : 

Response.Write(" 现 在 时 间 为 : " +DateTime.Now.ToString()); 
可 以 输出 当前 的 时 间 。 在 代码 呈现 块 中 ,如 果 只 有 一 个 输出 语句 ,例如 : 

< 

Response.Write "H A"); 

$» 
则 可 以 简写 为 : 

< =" % > 

(2) End 方法 。End 方法 用 来 输出 当前 缓冲 区 的 内 容 , 并 中 止 当 前 页 面 的 处 理 。 例 如 
程序 段 : 

Response. Write ("欢迎 光临 "); 

Response.End () ; 

Response.Write ("Jë НО ВЦ 1") ; 
只 输出 “欢迎 光临 ”, 而 不 会 输出 “我 的 网 站 !”。End 方法 常常 用 来 帮助 调试 程序 。 

(3) Redirect 方 法。 在 网 页 中 ,可 以 利用 超级 链接 把 访问 者 引导 到 另 一 个 页 面 , 但 访问 
者 必须 单 击 超级 链接 才 可 以 。 有 时 候 需 要 页 面 自动 重 定向 到 另 一 个 页 面 , 例 如 ,管理 员 没 有 
登录 而 访问 管理 页 面 , 就 需要 使 页 面 自动 跳 转 到 登录 页 面 。Redirect 方法 就 是 用 来 重 定向 
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页 面 的 ,例如 : 
Response Fedi rect ("login.aspx") ; 

可 以 将 当前 页 面 重 定向 到 当前 目录 下 的 login. aspx 页 面 。 也 可 以 转向 到 外 部 的 网 站 ,例如 : 
Response. Redi rect ("http://www.schu. oom") ; 


可 以 将 当前 页 面 重 定 向 到 搜狐 主页 。 

(4) ContentType 属性 。ContentType 属性 用 来 获取 或 设置 输出 流 的 HTTP MIME 类 型 ， 
也 就 是 Response 对 象 向 浏览 器 输出 内 容 的 类 型 ,默认 值 为 text/html, ContentType 的 值 为 字 
符 串 类 型 ,格式 为 ype/subtype,type 表示 内 容 的 分 类 ,subtype 表示 特定 内 容 的 分 类 。 例 如 : 

Response.ContentType ="image/gif"; 
表示 向 浏览 器 输出 的 内 容 为 gif 格式 的 图 片 。 

(5) BufferOutput 属性 。BufferOutput 属性 用 来 获取 或 设置 一 个 布尔 值 ,该 值 指示 是 否 
对 页 面 输出 进行 缓冲 。True 表示 先 输出 到 缓冲 区 ,在 完成 处 理 整 个 页 之 后 再 从 缓冲 区 发 送 
到 浏览 器 ; False 表示 不 输出 到 缓冲 区 ,服务 器 直接 将 内 容 输出 到 客户 端 浏览 器 ;默认 值 为 
True。 
如 果 使 用 了 Redirect 方法 对 页 面 进行 重 定向 , 则 必须 开启 输出 缓冲 ,因为 在 关闭 输出 组 
冲 的 情况 下 ,服务 器 直接 将 页 面 输出 到 客户 端 , 当 浏览 器 已 经 接收 到 HTML 内 容 后 ,是 不 多 
许 再 定向 到 另 一 个 页 面 的 。 

2. Request 对 象 

Request 对 象 是 由 类 System. Web. HttpRequest 来 实现 的 。 当 客户 请 求 ASP .NET ИШ 
时 ,所 有 的 请 求 信息 ,包括 请 求 报头 .请求 方法 .客户 端 基本 信息 等 都 被 封装 在 Request XJ Z 
中 ,利用 Request 对 象 就 可 以 读 取 这 些 请 求 信息 。Request 对 象 常用 的 属性 和 方法 如 
表 3-3 所 示 。 


表 3-3 Request 对 象 常用 属性 和 方法 


名 Ж 功能 说 明 
Browser 属性 获取 有 关 正在 请 求 的 客户 端的 浏览 器 功能 的 信息 
Cookies 属性 获取 客户 端 发 送 的 Cookie 的 集合 
Files 属性 获取 客户 端 上 传 的 文件 的 集合 
Form 属性 获取 表单 变量 的 集合 
QueryString 属性 获取 HTTP 查询 字符 串 变量 集合 
ServerVariables 属性 获取 Web 服务 器 变量 的 集合 
UserHostAddress 属性 获取 远程 客户 端的 主机 IP 地 址 
SaveAs 方法 将 HTTP 请 求 保存 到 磁盘 


在 Request 对 象 的 属性 中 ,有 些 表 示 的 是 数据 集合 , 像 Cookies , Form 等 ,获取 这 些 集合 
中 的 数据 的 语法 为 : 
«59. 


Recpest..Collection["key"] 
其 中 Collection 为 数据 集合 , key 为 集合 中 数据 的 关键 字 , Collection 为 Cookies, Form, 
QueryString \ServerVariables 4 种 集合 时 , 其 中 的 Collection. 可 以 省 略 ,也 就 是 说 Request 
["key" ]5j Request. Cookies [ " key" ] 两 种 写法 都 是 允许 的 。 如 果 省 略 了 Collection, Jill 
Request 对 象 会 依照 QueryString , Form , Cookies , ServerVariables 的 顺序 查找 ,直至 找到 关键 字 
为 key 的 数据 并 返回 数据 值 ;如 果 没 有 找到 , 则 返回 null。 建 议 最 好 使 用 Collection ,因为 在 
省 略 的 情况 下 可 能 返回 错误 的 值 ,而 且 , 过 多 的 搜索 也 会 降低 程序 执行 效率 。 

(1) UserHostAddress 属性 。UserHostAddress 属性 用 于 返回 用 户 的 IP 地址。 该 属性 返 
回 一 个 字符 串 类 型 的 值 。 

(2) QueryString 属性 。QueryString 属性 用 于 收集 来 自 请 求 URL 地 址 中 “?" 后 面 的 数 
据 ,这 些 数据 称 为 “查询 字符 串 ” ,也 称 为 "URL 附件 信息 ” ,通常 用 来 在 不 同 网 页 之 间 传 递 
数据 。 

(3) Browser 属性 。Request 对 象 的 Browser 属性 包含 众多 子 属性 ,用 来 返回 客户 端 浏 览 
器 的 信息 和 客户 端 操作 系统 的 信息 。 这 些 信息 有 时 是 必需 的 ,因为 客户 端 使 用 的 浏览 器 种 
类 或 设置 不 同 , 对 各 种 HTML 标记 的 支持 也 会 有 所 不 同 。 这 导致 同一 页 面 在 不 同 浏览 器 中 
显示 出 来 的 外 观 有 所 不 同 , 甚 至 会 出 现 错误 。 使 用 Request 对 象 的 Browser 属性 集 可 以 在 执 
行 代码 前 对 客户 端 浏 览 器 的 状况 进行 评估 ,以 便 有 选择 地 执行 某 些 代码 ,避免 造成 不 理想 或 
者 错误 的 页 面 效果 。 

例如 ,下 面 页 面 会 显示 关于 客户 端 浏 览 器 的 各 种 信息 ,用 不 同 浏览 器 查看 该 页 面 会 有 不 
同 的 结果 。 


«SG Page Language ="СЁ $ > 


«script runat -"server" > 

void Page Ioad(doject sender, EventArgs e) 

{ 

HttpBrowserCapabilities bc -Fequest.. Browser; 

list.Text ="; 
list.Text +R RI: "+bc.Platform+" <r>"; 
list.Text += EB Wim6 系统 : "+bc.Winl6 +" <br >"; 
list.Text +=" Win32 系统 : "+bc.Win32 +" <br>"; 
list.Text +=" --—" +" <br>"; 


list. Text + 一 浏览 器 : "tbc.Browser +" «br >"; 

list.Text + 二 浏览 器 标识 : "4bc.Id4" «br >"; 

list.Text + 二 浏览 器 版 本 : " ос. Version +" «br >"; 

list.Text + 一 浏览 器 MajorVersion: "tbc.MajorVersian.ToString() +" «br >"; 
list.Text + 一 浏览 器 MinorVersion: "Hbc.MinorVersion.TbString() +" «br >"; 
list.Text + 一 浏览 器 是 否 测试 版 本 : " +bc.Beta.ToString() +" <br >"; 
list.Text +=: mnerica mline 浏览 器 : " 4bc.20L +" «br >"; 

list.Text += 客 户 端 安装 的 ЛЕТ Framework 版 本 : " qbc.ClrVersicn +" «br >"; 
list.Text += 吓 否 移动 设备 : " +bc.IsMbileDevice +" «br >"; 
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list.Text +=" – jma be >"; 
list.Text +=" 显 示 的 颜色 深度 : " tbc.ScreerBitDepth +" «br >"; 
list.Text + 一 显示 的 近似 宽度 以 字符 行为 单位 ) " doc. Sereencbaractersitidth + 


"epo"; 
list.Text + 一 显示 的 近似 高 度 以 字符 行为 单位 ) : "+bc.ScreenCharactersHeight + 
"r >"; 


list.Text + 一 显示 的 近似 宽度 以 像素 行为 单位 ): " Hbc. ScreenPixelsidth +" «br >"; 


list.Text + 二 显示 的 近似 高 度 以 像素 行为 单位 ) : "bc.ScreenPixelsHeight +" br >"; 


list.Text +=" - --" 4" 4o"; 


list.Text += 是 否 支 持 CSS: " tbc.SupportsCss +" «br >"; 

list.Text += 吓 否 支持 Active 控件 : "+ 

bc.ActiveXcontrols.TcString () +" «br >"; 

list.Text += 吓 否 支持 Јамадррдеіѕ: " 4bc.Javalgnlets TeString() +" «br >"; 
list.Text +=" EMF JavaScript: " 4bc.JavaScript. ToString () +" «br >"; 
list.Text 4-"JScriptVersion: " bc. JScriptVersion.ToString() +" «br >"; 
list.Text +=" 194 VBScript: " 4bc. VBScript ToString () +" «br >"; 
list.Text +="ДЕЙ ЖИР Cookies: " tbc.Cookies +" «br >"; 

list.Text +=") MHIML 的 DOM 版 本 : " bc. MSDanVersicn +" «br >"; 
list.Text +=" w3c 的 DM 版 本 : " doc W3CDanersion +" «br >"; 
list.Text +=" 是 否 支持 通过 HTP 接收 УМ: "+ 

bc.SugportsilHttp +" «br >"; 

list.Text += 吓 否 支持 框架 : "tbc.Frames.ToString() +" «br >"; 

list.Text += 起 链接 а 属性 href 值 的 最 大 长 度 : " qpc.Maximmireflergth +" Фс >"; 
list.Text += 是 否 支持 表格 : " с. Tables +" «br >"; 


) 
«/script > 
<html xmlns ="http: /Aww.w3.org/1999/xhtml" > 
«head id -"Headl" runat ="server" > 
<title >ASP .NET 获取 客户 端 浏览 器 信息 </title> 
</head> 
«body > 
«form id ="foml" runat ="зегуег" > 
«div» 
«asp:label ID -"list" runat -"server" > «/asp:label > 
</div > 
</form> 
</body> 
</html > 


【任务 实施 】 
第 1 步 ， 新 建 一 个 空 项 目 ,并 在 该 项 目 中 新 建 一 个 Web 页 面 。 
第 2 步 ”在 页 面 中 添加 如 下 代码 : 


«SQ Page Language ="СЁ $ > 
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«script language —"Cf? rumat -"server" > 


void LstClick (doject serder, EventArgs е) 


{ 
int inti; 
for (inti-0; inti «lstbox.Items.Count; inti ++) 
{ 
if (lstbox.Items [inti] .Selected) 
í 
switch (lstbox.Items [inti] .Value) 
{ 
case "1": 
Response.Fedirect ("http://www .schu.oam") ; break; 
case "2": 
Fesponse. Fedi rect ("http: //wiw.sina.ocm.cn") ; break; 
case "3": 
Response. Fedi rect ("http: / /www.ifeng.coam") ; break; 
) 
) 


void WriteInfo(doject serder, EventArgs е) 


{ 
string strtemp ="; 
int intDatal, intData2; 
if (Request.Fonm["datal"] ! =" && Request.Form["data2"] ! ="") 
t 
intDatal -Ccnvert .ToInt32 (Request . Form["datal "]) ; 
intData2 -Ccnvert .ToInt32 (Request . Form["data2"]) ; 
strtemp -intDatal .ToString () +" +" HintData2 .ToString() +" ="; 
intDatal + 一 ntData27 
strterp +=intDatal .ToString () ; 
lakContentl .Text -strtemp; 
) 
</script > 
<html > 
«body » 


«form іа ="Foml" runat ="server" enctype -"miltipart/fom -data" > 

<asp:TextBox ID-"datal" runat -"server" / >+ 

<asp:TextBox ID-"data2" runat —"server" / >=? «br» 

«button id-"Buttonl" runat ="зегуег" onserverclick -"WriteInfo" > 
提交 </button ><br > 

<br > «asp:label nmt ="ѕегуег" ID-"laboontentl" /><br > 
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<br><asp:Iabel ID-"labCcntent2" > 导航 : </asp:Iabel ><br > 
<asp:ListBox ID="1stbox" гопа server" AutoPostBack ="true" 
SelectiorMode -"'single" 
Rows ="3" OnSelectedIndexChanged ="LstClick" > 
<asp:ListItem Text =" 0" Value ="1" Selected="false" /> 
<asp:ListItem Text = 新 浪 " Value ="2" Selected="false" /> 
<asp:ListItem Text = 凤凰" Value ="3" Selected="false" /> 
</asp:ListBox > 
<hr> 
</form> 
</body> 
«/html > 
第 3 步 按 了 五 键 或 单 击 工具 栏 上 的 启动 调试 按钮 ,运行 页 面 。 页 面 首次 加 载 时 ,页 面 
内 容 如 图 3-3 所 示 ;在 页 面 中 的 两 个 输入 框 中 分 别 输入 3 和 5, 单 击 “ 提 交 ” 按 钮 ,提交 表单 
到 服务 器 ,返回 页 面 如 图 34 所 示 ,服务器 将 计算 结果 显示 在 页 面 上 ; 单 击 导航 列表 框 中 的 
“搜狐 ”“ 新 浪 "“ 风 凰 "中 的 任意 一 项 ,页 面 会 跳 转 至 相应 的 网 站 首页 ,如 图 3-5 所 示 。 


D localhost:14829/WebSit x 


+ [5 


图 3-3 页 面 首次 加 载 


【任务 小 结 】 

本 任务 初步 认识 使 用 了 Request 和 Response 对 象 。 一 个 客户 端 请 求 是 使 用 Request 对 
象 来 表示 的 ,而 服务 器 响应 会 以 Response 对 象 来 表示 。Request 对 象 是 ASP . NET 中 用 于 提 
取 浏 览 嚣 中 用 户 输 入 信息 的 内 置 对 象 。 在 使 用 时 ,用 户 信息 可 以 通过 表单 来 提交 ,也 可 以 直 
接 用 URL 的 参数 来 获取 ,还 可 以 通过 环境 变量 来 提供 。Response 是 ASP . NET 用 于 控制 如 
何 将 相应 发 送 给 用 户 的 内 置 对 象 , 它 提供 了 丰富 的 方法 和 属性 用 于 控制 相应 的 输出 方式 。 


任务 3-3 使 用 Cookie 保存 客户 信息 


【任务 描述 】 
小 王 为 了 方便 用 户 , 需 要 把 用 户 的 信息 保存 起 来 ,实现 如 下 功能 : 第 一 个 页 面 让 用 户 选 
择 自己 的 身高 体重 以 及 个 人 爱好 , 存 人 客户 端的 Cookie 文件 中 ,然后 打开 第 二 个 页 面 ,自动 
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l D lecalhost14829/WebSit x 


€ > C |[localhost14829/Website5/ 
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图 34 输入 数字 提交 后 页 面 


E LREN х\ Е ч 
€ > С [www.sohu.com чт 三 
我 的 搜狐 |~ алаа 注册 dk dem 8 
搜狗 输入 法 浏览 器 地 图 邮件 DUO 博客 BBS 我 说 两 句 


新 闻 军事 文化 历史 读书 原创 评论 体育 NBA СВА : 
时 尚 хл ВА cum 美容 美食 星座 GU ВЕ 


最 新 2014 世 界 大 学 排名 。 2014 世 界 大 学 排名 ”会 中 文 就 会 说 英语 ”数理 化 ;3 步 巧 解法 


中 国 推出 Excel 服 务 器 。 “新 东方 报名 入 口 ` 林 卡 高 青 视频 电话 。 30 天 英语 升 职 加 堤 
冲 中 J2014 备 战 中 高 考 з " 
一 路 成 长 : WAEA 
B: 你 我 的 永生 器 绊 


WERNER 

gp BXHUDRUER 

B жїйє 

E ETOH? ОБДАРЕН k 大 神 直播 中 。 北京 
Bl 低龄 出 国 留学 指南 游戏 浏览 器 尽 抠 洲 戏 特权 6.2 折 抢 奶 粉 6.2 元 看 电影 。 1717 
` [re р 


图 3-5 ”转向 导航 页 面 


读 取 Cookie 信息 ,显示 用 户 的 身高 和 个 人 爱好 。 
【任务 目的 】 
熟悉 Cookie 的 基本 概念 和 用 法 。 
掌握 设置 和 读 取 Cookie 的 方法 ,实现 表单 自动 填写 或 个 性 化 服务 。 


【任务 分 析 】 
在 Web 中 处 于 中 心 的 是 Web 服务 器 ,用 来 处 理 客户 端的 HTTP 请 求 。 由 于 HTTP 是 一 
种 无 状态 的 连接 协议 ,对 于 每 个 Web 页 面 的 一 次 请 求 都 被 看 作 是 一 次 用 户 的 会 话 , 也 就 是 
它 并 不 记得 上 一 次 谁 请 求 过 它 ,不 会 主动 去 询问 客户 端 , 只 有 当 客 户 端 主动 请 求 之 后 ,服务 
器 才 会 响应 。 这 样 一 来 ,对 于 那些 需要 获知 客户 端 某 些 信息 或 者 保存 服务 器 与 客户 端 之 间 
的 交互 信息 的 网 页 来 说 ,比如 说 某 用 户 已 经 登录 网 站 成 功 ,需要 记 下 该 用 户 的 一 些 登录 信 
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息 ;再 如 某 些 网 站 设 有 个 性 化 的 显示 风格 ,如 果 没 有 某 种 手段 可 以 保存 用 户 的 喜好 就 显得 十 
分 不 方便 ,因为 用 户 需要 每 次 登录 网 站 都 重新 做 一 次 设置 。 

【基础 知识 】 

1. Cookie 简介 

Cookie 是 一 小 段 文 本 信息 ,伴随 着 用 户 请 求 同 页 面 一 起 在 Web 服务 器 和 浏览 器 之 间 传 
递 。 用 户 每 次 访问 站 点 时 , Web 应 用 程序 都 可 以 读 取 Cookie 包含 的 信息 。Cookie 为 Web 应 
用 程序 保存 用 户 相关 信息 提供 了 一 种 有 用 的 方法 ,例如 , 当 用 户 访问 一 个 网 站 时 ,网 站 程序 
员 可 以 利用 Cookie 保存 用 户 首选 项 或 其 他 信息 ,这 样 , 当 用 户 下 次 再 访问 这 个 网 站 时 ,应 用 
程序 就 可 以 检索 以 前 保存 的 信息 。 

Cookie 的 基本 工作 原理 可 以 通过 访问 网 站 的 过 程 来 说 明 。 假 设 用 户 请 求 访问 网 站 
www. oneweb. com 上 的 某 个 页 面 时 ,应 用 程序 发 送 给 该 用 户 的 不 仅仅 只 有 一 个 页 面 , 还 有 一 
个 包含 日 期 和 时 间 信 息 的 Cookie ,用 户 的 浏览 器 在 获得 页 面 的 同时 还 得 到 了 这 个 Cookie ,并 
且 将 它 保 存在 用 户 硬盘 上 的 某 个 文件 夹 中 。 以 后 ,如 果 该 用 户 再 次 访问 该 网 站 上 的 页 面 , 当 
用 户 输入 URL; www. oneweb. com 时 ,浏览 器 就 会 在 用 户 本 地 硬盘 上 查找 与 该 URL 相关 联 
的 Cookie。 如 果 该 Cookie 存在 ,浏览 器 就 将 它 与 页 面 请 求 一 起 发 送 到 网 站 ,应 用 程序 就 能 
读 取 Cookie 信息 ,从 而 能 确定 该 用 户 上 一 次 访问 网 站 的 日 期 和 时 间 。 程 序 可 以 根据 这 些 信 
息 向 用 户 输出 相应 的 消息 。Cookie 是 与 Web 站 点 而 不 是 与 具体 页 面 关联 的 ,所 以 无 论 用 户 
请 求 浏览 网 站 中 的 哪个 页 面 ,浏览 器 和 服务 器 都 将 交换 www. oneweb. com 的 Cookie 信息 。 
用 户 访问 其 他 网 站 时 ,每 个 网 站 都 可 能 会 向 用 户 浏览 器 发 送 一 些 Cookie ,而 浏览 器 会 将 所 有 
这 些 Cookie 分 别 保存 。 

小 提示 : 登录 界面 打开 时 ,用 户 名 直接 显示 出 来 而 不 用 填写 的 实现 技术 就 是 Cookies 

Cookie 也 是 一 种 进行 状态 管理 的 方法 , 它 最 根本 的 用 途 是 帮助 Web 应 用 程序 保存 有 关 
访问 者 的 信息 。 例 如 ,购物 网 站 上 的 Web 服务 器 跟踪 每 个 购物 者 ,以 便 网 站 能 够 管理 购物 
车 和 其 他 的 用 户 相关 信息 ;一 个 实施 民意 测验 的 网 站 可 以 简单 地 利用 Cookie 作为 布尔 值 ， 
表示 用 户 的 浏览 器 是 否 已 经 参与 了 投票 ,从 而 避免 重复 投票 ;而 那些 要 求 用 户 登录 的 网 站 则 
可 以 通过 Cookie 来 确定 用 户 是 否 已 经 登录 过 ,这 样 用户 就 不 必 每 次 都 输入 凭据 。 因 此 
Cookie 的 作用 就 类 似 于 名 片 , 它 提供 了 相关 的 标识 信息 ,可 以 帮助 应 用 程序 确定 如 何 继续 
执行 。 

知识 链接 : 在 网 站 中 使 用 Cookie 存在 着 一 些 限制 。 

(1) 大 多 数 浏览 器 支持 最 多 可 达 4096B 的 Cookie , 如果 要 将 为 数 不 多 的 几 个 值 保 存 到 
用 户 计算 机 上 ,这 一 空间 已 经 足够 大 ,但 不 能 用 一 个 Cookie 来 保存 数据 集 或 其 他 大 量 数据 。 

(2) 浏览 器 限制 每 个 站 点 可 以 在 用 户 计算 机 上 保存 的 Cookie 数 。 大 多 数 浏 览 器 只 允 
许 每 个 站 点 保存 20 个 Cookie。 如 果 试 图 保存 更 多 的 Cookie, 则 最 先 保存 的 Cookie 就 会 被 删 
除 。 还 有 些 浏 览 器 会 对 来 自 所 有 站 点 的 Cookie 总 数 做 出 限制 ,这 个 限制 通常 为 300 个 。 

(3) 用 户 可 以 设置 自己 的 浏览 器 ,拒绝 接受 Cookie。 

因此 ,尽管 Cookie 在 应 用 程序 中 非常 有 用 ,应 用 程序 也 不 应 该 依赖 于 能 够 保存 Cookie, 
利用 Cookie 可 以 做 到 锦上添花 ,但 不 要 利用 它们 来 支持 关键 功能 。 如 果 应 用 程序 必须 使 用 
Cookie , 则 可 以 通过 测试 来 确定 浏览 器 是 否 接受 Cookie, 
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2. 设置 Cookie 

可 以 使 用 Response 对 象 的 Cookies 属性 来 设置 Cookie ,设置 Cookie 就 是 向 Cookies 集合 
里 添加 Cookie 对 象 ,Cookie 对 象 是 由 System. Web. HttpCookie 类 来 实现 的 , 它 的 常用 属性 如 
表 3-4 所 示 。 


表 3-4 Cookie 对 象 常用 属性 


# Ж 说 ш 

Name 获取 或 设置 Cookie 的 名 称 

Expires 获取 或 设置 Cookie 的 过 期 日 期 和 时 间 

Domain 获取 或 设置 Cookie 关联 的 域 

HasKeys 获取 一 个 值 ,通过 该 值 指示 Cookie 是 否 具有 子 键 

Path 获取 或 设置 要 与 Cookie 一 起 传输 的 虚拟 路 径 

Secure 获取 或 设置 一 个 值 , 通 过 该 值 指示 是 否 安全 传输 Cookie 
Value 获取 或 设置 单个 Cookie 值 

Values 获取 在 单个 Cookie 对 象 中 包含 的 键 值 对 的 集合 


(1) Name 属性 。 设 置 一 个 Cookie ,需要 通过 相应 的 属性 指定 一 些 值 。 通 过 Cookie 的 
Name 属性 来 指定 Cookie 的 名 字 ,因为 Cookie 是 按 名 称 保存 的 ,如 果 设置 了 两 个 名 称 相同 的 
Cookie, 后 保存 的 那 一 个 将 覆盖 前 一 个 ,所 以 创建 多 个 Cookie 时 ,每 个 Cookie 都 必须 具有 唯 
一 的 名 称 , 以 便 日 后 读 取 时 识别 。 

(2) Value 属性 。Cookie 的 Value 属性 用 来 指定 Cookie 中 保存 的 值 ,因为 Cookie 中 的 值 
都 是 以 字符 串 的 形式 保存 的 ,所 以 为 Value 指定 值 时 ,如 果 不 是 字符 串 类 型 则 要 进行 类 型 
转换 。 

(3) Expires 属性 。Cookie 的 Expires 属性 为 DateTime 类 型 ,用 来 指定 Cookie 的 过 期 日 
期 和 时 间 : Cookie 的 有 效 期 。Cookie 一 般 都 写 入 到 用 户 的 磁盘 , 当 用 户 再 次 访问 某 个 网 站 
时 ,浏览 器 会 先 检 查 这 个 网 站 的 Cookie 集合 ,如 果 某 个 Cookie 已 经 过 期 ,浏览 器 不 会 把 这 个 
Cookie 随 页 面 请 求 一 起 发 送 给 服务 器 ,而 是 适当 的 时 候 删除 这 个 已 经 过 期 的 Cookie。 如 果 
不 给 Cookie 指定 过 期 日 期 和 时 间 , 则 为 会 话 Cookie ,不 会 存 信 用户 的 硬盘 ,在 浏览 器 关闭 后 
就 被 删除 。 应 根据 应 用 程序 的 需要 来 设置 Cookie 的 有 效 期 ,如果 利 用 Cookie 来 保存 用 户 的 
首选 项 , 则 可 以 把 其 设置 为 永远 有 效 ( 例如 100 年 ) ,因为 定期 重新 设置 首选 项 对 用 户 而 言 
是 比较 麻烦 的 ;如 果 利用 Cookie 统计 用 户 访问 次 数 , 则 可 以 把 有 效 期 设置 为 半年 ,如 果 某 个 
用 户 已 有 半年 时 间 未 访问 , 则 可 以 把 该 用 户 访问 次 数 归 0。 需 要 注意 的 是 用 户 可 以 随时 删 
除 自己 计算 机 上 的 Cookie ,所 以 即使 设置 Cookie 长 期 有 效 , 用 户 也 可 以 自行 决定 将 其 全 部 
删除 ,同时 清除 保存 在 Cookie 中 的 所 有 设置 。 

下 面 程序 段 设置 一 个 名 字 为 userage 的 Cookie ,有效 期 为 3 天 。 

Response. Cookies ["userage"] -Value-23.Tostring(0; 

Response. Cookies ["userage"] .Expires -DateTrine Now. Аа нуз (3); 


也 可 以 先 创建 一 个 Cookie 对 象 ,再 添加 进 Response. Cookies 集合 ,下 面 程序 段 实现 同样 的 
A 


功能 。 


HttpOockie myoookie -new HttpCookie ("Userage"); 
// 生 成 一 个 名 字 为 userage 的 Cookie 对 象 


mycookie.Value =23 .ToString () ; // 设 置 cookie 的 值 
myoockie.Expi res =ГабеТіпе Now .ActiDays (3) ; // 设 置 过 期 日 期 和 时 间 
Response.Cookies .Add (mycookie) ; ГАЮ cookie 对 象 添 加 到 Везропзе.Соокіеѕ 集合 


上 面 程序 段 中 ,一 个 Cookie 对 象 只 存储 了 一 个 值 ,也 可 以 在 一 个 Cookie 中 存储 多 个 值 ， 
这 样 的 Cookie 称 为 多 值 Cookie ,在 编程 中 , 常 使 用 它 来 存储 一 组 相关 或 类 似 的 信息 。 多 值 
Cookie 中 ,包含 一 个 或 多 个 子 键 , 每 个 子 键 对 应 一 个 值 , 可 以 通过 查看 Cookie 对 象 的 
HasKeys 属性 来 判断 是 否 为 多 值 Cookie 

下 面 程序 段 设 置 一 个 名 字 为 user 的 多 值 Cookie, 包含 两 个 子 键 username 和 userage , 有 
效 期 为 3 天 。 

Response. Cookies ["user"] ["username"] ="; 

Response.Cockies ["user"] ["userage"] -23.ToString() ; 

Response.Cockies ["user"] .Expires =DateTime.Now.nddDays (3) 7 
也 可 以 用 下 面 的 程序 段 实 现 同 样 的 功能 。 

HttpCookie mycookie new HttpCookie ("user") ; 

mycookie.Values ["usemame"] =k ="; 

mycookie.Values ["userage"] -23.ToString() ; 

myoockie.Expi res DateTime Now. ActDays (3) ; 

Response Cookies .Ack (myoookie) ; 

(4) Paht 和 Domain 属性 。 设 置 Cookie 对 象 的 Path 属性 可 以 把 Cookie 的 有 效 范围 限制 
到 服务 器 上 的 某 个 目录 中 ;设置 Cookie 对 象 的 Domain 属性 可 以 把 Cookie 的 有 效 范围 限制 
到 某 个 域 。 

3. 读 取 Cookie 

当 用 户 向 网 站 发 出 请 求 时 ,该 网 站 的 Cookie 会 与 请 求 一 起 发 送 。 在 ASP . NET 应 用 程 
序 中 ,可 以 使 用 Request 对 象 的 Cookies 属性 来 读 取 Cookie 信息 。 

在 读 取 Cookie 的 值 之 前 ,应 该 确保 该 Cookie 确实 存在 。 和 否则 ,将 得 到 一 个 “未 将 对 象 引 
用 设置 到 对 象 实例 "的 异常 。 

例如 , 读 取 名 字 为 username 的 Cookie ,并 将 值 显示 在 labell 控件 中 。 

if (Reguest.Cockies ["userreme"'] ! -null) 

{ 

Labell .Text equest .Cookies ["rusername"] -Value; 


也 可 以 用 另 一 种 方法 实现 同样 的 功能 ,例如 : 


if (Request.Cookies [usernare"] ! null) 
{ 
HttpCockie mycookie -Bequest .Cockies ["'usernare"] ; 
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labell.Text -mycockie.Value; 
} 


如 果 读 取 的 为 多 值 Cookie ,需要 使 用 子 键 来 获得 值 , 例 如 ,下 面 程序 段 读 取 名 字 为 user， 
子 键 为 username 和 userage 的 Cookie 值 , 并 显示 在 labell 和 label2 控件 中 。 
if (Request.Cookies ["user"] ! 2nill) 
{ 
/下面 两 语句 作用 相同 
//labell.Text -Request .Cookies [userreme"'] .Values["username"]; 
labell.Text -Reguest..Cockies ["изегпате"] "username" ] 
label2.Text -Request .Cockies ["username"] ["'userage"] ; 
) 
4. 修改 和 删除 Cookie 
有 了 时 ,会 需要 修改 某 个 Cookie ,更 改 其 值 或 延长 其 有 效 期 等 。 尽 管 可 以 从 Request. 
Cookies 集合 中 获取 Cookie 并 对 其 进行 操作 ,但 Cookie 本 身 仍然 存在 于 用 户 硬盘 上 的 某 个 
地 方 。 因 此 ,修改 某 个 Cookie ,实际 上 是 指 用 新 的 值 创建 新 的 Cookie ,并 把 该 Cookie 发 送 到 
浏览 吉 ,覆盖 客户 机 上 旧 的 Cookies 
删除 Cookie 是 修改 Cookie 的 一 种 形式 。 由 于 Cookie 位 于 用 户 的 计算 机 中 ,所 以 无 法 直 
接 将 其 删除 。 但 是 ,可 以 修改 Cookie 将 其 有 效 期 设置 为 过 去 的 某 个 日 期 ,从 而 让 浏览 器 删 
除 这 个 已 过 期 的 Cookie。 


【任务 实施 】 

第 1 步 选择“ 文件 "1* 新 建 "1“ 网 站 "菜单 命令 ,打开 “新 建 网 站 ”对 话 框 ,选择 ASP 
. NET 空 网 站 ”, 单 击 “ 确 定 "按钮 ,成 功 创建 一 个 空 网 站 项 目 。 

第 2 步 ” 光标 停 留 在 解决 方案 管理 器 中 的 当前 项 目 根 目录 上 , 右 击 ,从 弹出 的 快捷 菜单 
中 选择 “添加 新 项 "命令 ,在 弹出 的 对 话 框 中 选择 “Web £r DR" , 单 击 “ 添 加 "按钮 ,成 功 添加 
一 个 名 称 为 defalut. aspx 的 ASP . NET 网 页 。 

第 3 步 打开 default. aspx, 添 加 如 下 代码 ; 


«SG Page Language ="CP $ > 


«script language ="С runat ="server" > 

void butclick (doject serder, EventArgs e) 

{ 
int inti; 
HttpCookie cookie -new HttrCookie ("pereferenoe") ; 
DateTime dn =DateTime.Now7 
TimeSpan ts new TimeSpan (30, 0, 0, 0); 
cockie.Expires -dn +5; 
for (inti-0; inti «-lstboxsports.Items.Count -1; inti ++) 
{ 

if (lstboxsports.Items [inti] .Selected) 
cockie.Values.Acd("sports", lstboxsports.Ttems [inti] Маје); 
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) 
cockie.Values.Adi ("height", txtheight.Text); 
cockie.Values.Ac "weight", txtweight.Text); 
Response. AppendCockie (cookie) ; 
labocntent.Text "您 的 运动 偏爱 已 经 记录 下 来 了 !"; 
} 
</script > 
<html > 
<body> 
«form іа ="Forml" runat ="server" > 
身高 «asp:TextBox ID="txtheight" runat ="server" / ><br > 
体重 <asp:TextBox ID="txtweight" runat ="server" / > «br» 
请 选择 您 的 运动 偏爱 «г > 
<asp:ListBox ID-"'1stboxsports" runat ="server" SelectiorMode ="single" > 
<asp:ListItem Value ="f# 3E Ji " > 健美 操 </asp:TistItem> 
<asp:ListItem Value 一 跑步 "> 跑步 «/asp:listItem» 
<asp:ListItem Value 一 游泳 " 游泳 «/asp:listItem» 
</asp:ListBox > 
<r> 
«asp:Button runat ="server" ID="yes" Text =" ОССК "butclick" / ><br > 
<asp:Label runat ="server" ID -"laboontent" /> 
</form> 
</body> 
</html > 


第 4 步 TES 键 或 单 击 工具 栏 上 的 “启动 调试 "按钮 ,运行 页 面 。 页 面 首次 加 载 时 ,页 
面 内 容 如 图 3-6 所 示 。 


€ > С |[3localhost:14806/WebsSite3/Default.aspx 安 | 三 


185 
160 
请 选择 您 的 运动 信和 
跑步 F 
AD 


- 


您 的 运动 偏爱 已 经 记录 下 来 了 ! 


图 3-6 ”页面 首次 加 载 


第 5 步 ” 在 输入 框 中 输入 自己 的 身高 和 体重 ,在 列表 框 中 选择 自己 的 爱好 。 单 击 “ 选 
择 " 按 钮 ,返回 页 面 如 图 3-7 所 示 , 提 示 用 户 信息 已 经 记录 下 来 。 
第 6 步 ”修改 default. aspx, 修 改 后 的 代码 如 下 : 
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图 3-7 单 击 “选择 "后 的 页 面 


«SG Page Language ="СЁ $ > 


«html > 
«script language ="СЁ' runat ="server" > 
protected void Page Ioed(doject sender, EventArgs e) 
t 
string strtemp; 
strterp 一 您 的 个 人 信息 记录 如 下 : "+" <br >"; 
strterp+= 和 运动 偏爱 =" «Request. Cookies ["preference"] ["sports"] +" «br >"; 
strtemp +="Ё} =" 4Recuest .CGookies ["preference"] ["height"] .TeString () + 
"г>"; 
strterp +="|K3Ë =" +Request.Cookies ["preference"] [weight"] .ToString() + 
"r>"; 
labocntent.Text =strtenp; 
} 


</script> 
<body> 
«form id "Fom" runat ="server" > 
«asp:label nmt -"server" ID -"laboontent" /> 
</fom> 
</body> 
«/ntml > 
第 7 步 FÈ 五 键 或 单 击 工具 栏 上 的 “启动 调试 "按钮 ,运行 页 面 ,页 面 效 果 如 图 3-8 所 示 ， 
服务 器 直接 在 Cookie 中 读 取 了 客户 的 个 人 信息 ,并 显示 出 来 。 
【任务 小 结 】 
Cookie 是 用 来 在 客户 端 和 服务 器 之 间 进 行 交 换 的 小 段 信息 。Cookie 有 会 话 Cookie 和 永 
久 Cookie 两 种 形式 。 会 话 Cookie 是 临时 性 的 ,保存 在 用 户 的 内 存 中 而 不 是 在 硬盘 上 ,只 有 浏 
览 器 打开 时 才 会 存在 ,一 旦 会 话 结束 或 超时 ,相应 的 Cookie 就 会 被 删除 。 永 久 Cookie 则 是 永 
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€ > С [ilocalhost14806/WebSite3/Defaultaspx тү 三 
您 的 个 人 信息 记录 如 下 ， 
运动 偏爱 = 健美 操 


ER 
高 =185 


体重 =160 


图 3-8 UB Cookie 显示 用 户 信息 


久 性 地 存储 在 硬盘 上 ,并 且 在 指定 的 过 期 日 期 之 前 一 直 可 以 使 用 。 
任务 34 fi FH Session 控制 访问 


【任务 描述 】 

小 王 的 网 站 开发 结束 ,客户 却 不 满意 ,因为 不 登录 也 可 以 访问 系统 ,安全 性 得 不 到 保障 。 
因此 需要 添加 访问 控制 。 

本 任务 创建 一 个 多 页 面 的 网 站 ,只 有 当 用 户 登 录 成 功 以 后 才能 访问 其 他 页 面 , 如 果 直 接 访 
问 其 他 页 面 则 需要 判断 用 户 是 否 已 经 登录 成 功 ,如 果 未 登录 成 功 则 自动 定位 到 用 户 登 录 页 面 。 


【任务 目的 】 

THE Session 对 象 的 作用 。 

掌握 使 用 Session 对 象 来 记录 用 户 信息 的 方法 。 

【任务 分 析 】 

在 Web 应 用 程序 和 网 站 中 ,往往 存在 一 些 比较 特殊 的 页 面 ,需要 记录 用 户 和 客户 端 之 间 
会 话 产生 的 一 些 信息 。 比 如 ,用 户 登录 网 站 后 ,应 该 记录 下 用 户 的 登录 信息 ,用 户 访问 网 站 的 
其 他 页 面 时 ,可 以 根据 当前 会 话 用 户 的 登录 情况 为 用 户 开 启 不 同 的 操作 权限 。 不 同 的 页 面 需 
要 验证 用 户 是 否 已 经 登录 ,以 及 用 户 属于 什么 权限 级 别 。 其 中 内 置 对 象 Session 就 是 用 来 保存 
会 话 信息 的 。 


【基础 知识 】 
小 提示 : Session 是 为 了 弥补 网 页 的 不 足 出 现 的 技术 ,因此 几乎 每 个 应 用 程序 都 会 使 用 到 
Session 对 象 。 


Session 的 工作 原理 是 相当 复杂 的 。 当 一 个 会 话 启动 时 ,ASP . NET 会 自动 产生 一 个 长 的 
SessionID 字符 串 对 会 话 进行 标识 和 跟踪 ,该 字符 串 只 包含 URL 中 所 允许 使 用 的 ASCII 字符 ， 
是 使 用 保证 唯一 性 和 随机 性 的 算法 生成 的 ,其 中 保证 唯一 性 的 目的 是 确保 会 话 不 冲突 ,保证 随 
机 性 的 目的 是 确保 怀 有 恶意 的 用 户 不 能 使 用 新 的 SessionID 来 计算 现 有 会 话 的 SessionID ,可 以 
通过 Session 对 象 的 SessionID 属性 来 查看 SessionID 值 。 

NE 


通常 情况 下 ,SessionID 会 存放 在 客户 端的 Cookies 内 , 当 用 户 访问 应 用 程序 任何 页 面 时 ， 
SessionID 会 通过 Cookies 传递 到 服务 器 端 ,服务 器 根据 SessionID 来 对 用 户 进行 识别 ,就 可 以 返 
回 用 户 对 应 的 Session 信息 。 也 可 以 通过 配置 应 用 程序 ,使 在 不 要 求 客户 端 浏 览 器 支持 
Cookies 的 情况 下 使 用 Session ,此 时 ,SessionID ЖАЛ. Cookies , MŒ A IRETE URL 中 ,服务 
器 可 以 通过 请 求 的 URL 获得 SessionID 值 , 这 在 浏览 器 不 支持 或 禁用 Cookies 功能 的 情况 下 非 
常 有 用 。 

知识 链接 : Session 是 为 了 弥补 网 页 访问 无 状态 而 设计 的 ,通过 Session 使 用 可 以 对 系统 的 
权限 进行 控制 等 。 

根据 配置 应 用 程序 的 方式 ,Session 中 信息 的 存储 位 置 可 以 是 ASP . NET 进程 状态 服务 
fit .SQL Server 数据 库 ,ASP . NET 在 相应 的 位 置 根据 SessionID 值 存储 或 读 取 个 人 状态 信息 。 

Session 的 生命 周期 是 有 限 的 ,默认 为 20 分 钟 ,可 以 通过 Session 对 象 的 Timeout 属性 来 设 
置 。 在 Session 的 生命 周期 内 ,Session 的 值 是 有 效 的 ,如 果 用 户 在 大 于 生命 周期 的 时 间 里 没有 
再 访问 应 用 程序 ,Session 就 会 自动 过 期 ,Session 对 象 就 会 被 释放 ,其 存储 的 信息 也 就 不 再 
有 效 。 

Session 对 象 常用 的 属性 和 方法 如 表 3-5 所 示 。 

表 3-5 Session 对 象 常用 属性 和 方法 
名 Ж 功能 说 明 
Count 属性 获取 会 话 状态 集合 中 的 对 象 个 数 

传 回 或 设置 Session 对 象 变量 的 有 效 时 间 ,如果 在 有 效 时 间 内 有 没有 任何 客户 端 动作 ， 


TimeOut 属性 


则 会 自动 注销 
Mode 属性 获取 当前 会 话 状态 的 模式 
Add 方法 创建 一 个 Session 对 象 
Abandon 方法 d "L Um 当前 会 话 并 清除 对 话 中 的 所 有 信息 ,如 果 用 户 重新 访问 页 面 , 则 可 以 创 


Clear 方法 此 方法 将 清除 全 部 的 Session 对 象 变量 ,但 不 结束 会 话 
Remove 方法 移 除 指定 的 Session 对 象 变量 


【任务 实施 】 

第 1 步 创建 一 个 空 网 站 项 目 ,并 在 新 项 目下 添加 3 个 窗 体 ,分 别 命名 为 index. aspx, 
login. aspx 和 admin. aspx。 

第 2 步 ”在 解决 方案 资源 管理 器 中 ,光标 移动 至 index. aspx, 右 击 ,从 弹出 的 快捷 菜单 中 选 
择 “ 设 为 起 始 页 ” ,将 index 作为 项 目的 起 始 页 面 。 

第 3 步 ”打开 index. aspx, 添 加 如 下 代码 : 


<%@Расе Language ="CP $ > 
«html > 
«head id-"Headl" runat -"server" > 
«title E </title> 
</head > 
2g s 


body » 
«form id-"fomi" runat "server" > 
«div» 
这 是 网 站 首页 ,管理 员 需 «a href ="login.aspx" > 登录 «/a 对 能 进入 
«a href ="айпіп.азрк" AF EJU </а >, 
</div> 
</fom> 
</body> 
</html > 


第 4 步 ЎТ login. aspx, 添 加 如 下 代码 : 


«S Page Language ='СР $ > 


«script runat ="server" > 
protected void Buttonl Click(doject sender, EventArgs e) 
{ 
// 定 义 登 录 失 败 时 弹出 信息 框 的 客户 端 脚本 
string stmo =" <script »alert (' 用 户 名 或 密码 不 正确 1"); <" +"/script >"; 
// 判 断 是 否 为 管理 员 ,在 实际 应 用 中 ,用 户 名 和 密码 一 般 都 存在 数据 库 中 
// 应 先 从 数据 库 中 读 出 再 进行 判断 
if (username.Text ==" && userpass.Text =="1234567") 
t 
// 登 录 成 功 ,把 用 户 名 和 密码 都 存 人 Session 对 象 中 
Session ["rusermame"] Aisermare.. Text; 
Session ["userpass"] -userpass Text; 
// 把 页 面 转向 到 admin.aspx 
Response.Fedi rect ("adnin.asp") ; 


// 登 录 不 成 功 ,并 弹出 信息 
Расе Fegistex Cl ientScriptBlock ("loginno", stmo) ; 


) 
</script> 


«ntml > 

«head id —Headl" runat ="server" > 
«title > 登录 页 面 title> 
«style type =" css" > 


</style> 
«/read > 
«body > 
«fom id -"fomil" nmt ="ѕегуег" > 
«table align ="œnter" class -"stylel" > 
<tr> 
<td align ="œnter" aolspan 22" > 
管理 员 登 录 </td> 
</tr> 
<tr> 
«td align "right" class ="style3" > 
姓名 &riosp; &riosp; nbsp; 
</td> 
<td class ="style2" width ="50%" > 
<asp:TextBox ID -"userarre" nmt ="server" > </asp: TextBox > 
</td> 


<td align ="richt" class ='style3" > 
密码 &ribsp; апор; агер; 
</td> 
<td class ="style2" > 
<asp:TextBox ID -"userpass" nmt ="server" TextMode -"Password" > 
</asp:TextBox > 
</td> 
</tr> 
<tr> 
«td align =" " olsn 22" > 
«asp:Batton ID-"Buttcri" ruat ="server" onclick -"Battonl Click" 
Text =" 有 登录 " /> 
</td> 
</tr> 
</table > 
</form> 
</body> 
</html > 


955 25 打开 admin. aspx, 添 加 如 下 代码 : 
„73+ 


«SQ Page Language ="СЁ $ > 
«script runat -"server" > 
private void Page Load(doject sender, System.EventArgs е) 
t 
// 刊 断 相应 的 Session 信息 是 否 存在 
if (Session["username"] ! -null && Session["userpass"] ! null) 
{ 
// 相 应 的 Session 信息 存在 ,进一步 判断 是 否 为 管理 员 
string username -Session ["изеттите"] .ToString () ; 
string userpass -Session ["userpass"] .ToString () ; 
if (username ! =" || userpass ! ="1234567") 
{ 
// 不 是 管理 员 , 自 动 转 到 登录 页 面 并 终止 执行 当前 页 
Fesponse.Fedirect ("login.aspk", true); 


// 相 应 Sessicn 信息 不 存在 ,自动 转 到 登录 页 面 并 终止 执行 当前 页 
Respcnse.Redirect ("login.aspx", true); 


) 
</script > 


<html xmlns ="http://ww.w3 .org/1999/xhtml " > 
«head id ="Head1" runat ="server" > 
«title > 管理 页 面 </title> 
</head> 
«body» 
«form id "formi" runat ="server" > 
«div» 
«span ЭРИНИ : 你 现在 可 以 对 网 站 进行 管理 了 ! </span > </div > 
</form> 

</body> 

</html > 

第 6 步 BEES 键 或 单 击 工具 栏 上 的 “启动 调试 "按钮 ,运行 页 面 ,页 面 效果 如 图 3.9 
Bos. 

第 7 步 。 单 击 index. aspx 页 面 上 的 “登录 " 超 链 接 ,进入 login. aspx 页 面 ,或 者 单 击 “管理 
页 面 " 超 链接 ,结果 系统 并 未 进入 管理 界面 ,而 是 重 定向 到 了 login. aspx 页 面 。login. aspx 页 面 
效果 如 图 3-10 所 示 。 

第 8 步 在 login. aspx 页 面 中 输入 姓名 : 张 三 ,密码 : 1234567。 单 击 登 录 , 登 录 成 功 ， 
系统 会 自动 跳 转 到 admin. aspx 页 面 ,页 面 效 果 如 图 3-11 所 示 。 返 回 index. aspx, 再 次 单 击 
“管理 页 面 " 超 链 接 ,系统 不 会 再 重 定向 到 login. aspx 页 面 ,而 是 进入 admin. aspx, 因为 用 户 

9052 


€ > C Г localhost:14829/WebSite5/index.aspx 


这 是 网 站 首页 ， 管 理 员 需 登录 才能 进入 管理 页 面 。 


€ > С [localhost:14829/WebsSite5/login.aspx 


管理 员 登 录 
姓名 
密码 


图 3-10 login. aspx 页 面 效 果 
已 经 登录 成 功 ,用 户 的 登录 信息 已 经 保存 在 Session 中 。 


> Ç |D localhost:14829/WebsSite5/admin.aspx 
管理 员 ， 你 现在 可 以 对 网 站 进行 管理 了 ! 


图 3-11 login. aspx 页 面 效 果 
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【任务 小 结 】 

Session 对 象 的 作用 是 在 服务 器 端 存储 特定 信息 ,但 与 Application 对 象 存储 信息 是 完全 
不 同 的 ,Application 对 象 存储 的 信息 是 整个 应 用 程序 共享 的 全 局 信息 ,每 个 客户 访问 的 是 相 
同 的 信息 ,而 Session 对 象 存储 的 信息 是 局 部 的 ,是 特定 于 某 一 个 用 户 的 ,Session 中 的 信息 也 
称 为 会 话 状态 。 利 用 Session 对 象 ,可 以 在 客户 访问 一 个 页 面 时 ,存储 一 些 信息 , 当 转 到 下 一 
个 页 面 时 ,再 取出 信息 使 用 ,比如 ,在 设计 论坛 网 站 时 ,可 以 在 客户 登录 成 功 后 把 用 户 名 和 和 密 
码 存 入 Session ,在 其 他 发 帖 页 面 或 回复 页 面 ,就 可 以 直接 使 用 Session 中 的 用 户 名 和 密码 来 
判断 客户 是 否 有 权限 进行 操作 ,而 不 需要 让 客户 再 次 输入 用 户 名 和 密码 。 在 购物 车 程序 中 ， 
也 常用 Session 来 保存 用 户 在 浏览 商品 过 程 中 所 购物 品 的 信息 。 


四 、 项 目 小 结 


本 项 目 通过 4 个 任务 讲解 了 ASP . NET 的 内 置 对 象 , 内 置 对 象 在 ASP 时 代 十 分 重要 ,在 
ASP .NET 中 使 用 频率 下 降 不 少 ,但 仍然 是 开发 中 不 可 或 缺 的 技术 ,尤其 是 Session 对 象 ,是 
一 个 成 熟 系统 必 不 可 少 的 一 项 技术 。 


五 、 项 目 考核 


1. 填空 题 

(1) Request 对 象 的 属性 用 来 获取 HTTP 查询 字符 串 变 量 的 集合 。 

(2) 对 象 可 以 输出 信息 到 客户 端 ,包括 直接 发 送信 息 给 浏览 器 . 重 定 向 浏览 器 
到 另 一 个 URL 或 设置 Cookie 对 象 。 

(3) 对 象 为 当前 用 户 会 话 提供 信息 ,还 提供 对 可 用 于 存储 信息 的 会 话 范 围 的 
缓存 的 访问 ,以 及 控制 如 何 管理 会 话 的 方法 。 

2. 选择 题 

(1) Server 对 象 的 ScriptTimeout 属性 可 以 获取 或 设置 页 面 超时 时 间 , 它 的 超时 时 间 默 
认 值 为 ( ) 秒 。 

A. 100 B. 90 C. 120 D. 60 
(2) 下 面 程序 执行 完毕 ,页 面 上 显示 的 内 容 是 ( Js 


Response.write (" «a href -'http://www.baidu.om' > 百度 </a >") 


A. 百度 ( 超 链接 ) 
B. «a href = http://www. baidu. com' > HE «/a» 
C. 百度 
D. 语法 错误 
(3) Application 对 象 的 默认 有 效 期 为 ( 。” ”) 分 钟 。 
A. 10 В. 15 
C. 20 D. 应 用 程序 从 启动 到 结束 


(4) 通过 Request 对 象 的 ( ) 方 法 可 以 获取 当前 请 求 的 虚拟 路 径 。 
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A. Path B. MapPath C. QueryString D. Browser 
(5) Session 对 象 的 ( ) 属性 可 以 帮助 统计 正在 使 用 的 对 象 的 个 数 。 
A. Add B. Clear C. TimeOut D. Count 
3. 简 答 题 
(1) 简 述 如 何 把 页 面 重 定向 到 另外 一 个 页 面 。 
(2) 简 述 Session 对 象 的 有 效 时 间 。 
(3) Request 对 象 如 何 获取 客户 端 和 浏览 器 信息 ? 
4. 上 机 操作 题 
编程 实现 登录 。 目 标 如 下 : 
(1) 登录 成 功 后 ,下 次 登录 时 ,用 户 名 直接 填 好 ,不 再 需要 用 户 再 次 输入 。 
(2) 实现 页 面 访问 的 控制 : 不 登录 不 能 访问 登录 后 的 页 面 ,IP 地 址 必须 在 某 一 个 范围 
内 才能 访问 。 


Re 


项 目 4 服务 器 控件 
一 、 引 言 


当前 ,应 用 程序 都 是 使 用 网 页 作为 系统 入 口 ,系统 的 用 户 接 口 就 是 网 页 , 足 可 见 网 页 是 
最 基本 的 也 是 最 重要 的 载体 。 在 ASP . NET 中 网 页 的 设计 主要 使 用 控件 ,ASP . NET 提供 的 
控件 能 够 极 大 地 提高 开发 效率 。 

ASP .NET 服务 器 控件 是 ASP . NET 提供 的 控件 中 最 重要 的 控件 ,同时 也 是 非常 基础 的 
内 容 。ASP .NET 的 服务 器 控件 可 以 分 为 几 大 类 。 

(1) HTML 服务 器 控件 : 简单 封装 HTML 元 素 的 控件 。 

(2) Web 服务 器 控件 : 这 些 控件 不 但 具有 HTML 的 功能 ,而 且 提供 了 更 多 有 用 的 属性 
和 方法 ,使 开发 人 员 更 容易 定义 和 访问 ,是 本 项 目的 重点 。 

(3) 验证 控件 : 对 数据 进行 验证 的 控件 。 

(4) 数据 控件 : 显示 大 量 数据 的 控件 ,本 项 目 不 涉 及 ,会 在 后 续 项 目 中 学 习 。 

(5) 导航 控件 : 具有 导航 功能 的 控件 ,如 菜单 等 。 

(6) ASP .NET AJAX 控件 : 在 不 用 编写 客户 端 代码 的 基础 上 实现 AJAX。 本 项 目 不 涉 
及 ,会 在 后 续 项 目 中 学 习 。 


二 、 项 目 要 点 


本 项 目 通过 4 个 任务 讲解 Web 服务 器 控件 ,验证 控件 .导航 控件 以 及 母 版 页 的 使 用 ,要 
求 掌 握 服务 器 控件 的 基本 概念 ;掌握 常用 Web 服务 器 控件 的 主要 属性 及 其 使 用 ;掌握 验证 
控件 验证 数据 的 方法 ;掌握 使 用 导航 控件 设计 网 页 导航 方法 ;掌握 网 页 设计 中 母 版 页 的 设计 
和 使 用 方法 。 


= E% 
任务 4-1 使 用 服务 器 控件 设计 注册 页 面 
【任务 描述 】 


小 王 本 来 在 学 习 ASP 技术 ,页 面 开发 总 是 麻烦 不 断 , 令 他 苦恼 不 已 。 周 围 的 朋友 告诉 
他 ,ASP .NET 开发 网 页 方便 高 效 , 很 多 问题 都 能 迎刃而解 。 因 此 他 试 着 使 用 ASP . NET JF 
发 注册 页 面 。 
【任务 目的 】 
(1) 掌握 TextBox Label , Button 等 控件 的 主要 属性 。 
(2) 掌握 TextBox Label. Button 等 控件 在 网 页 设计 中 的 使 用 。 
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(3) 使 用 常用 的 Web 服务 器 控件 实现 注册 页 面 效 果 。 


【任务 分 析 】 

在 ASP 和 JSP 技术 中 ,网 页 的 设计 与 制作 是 比较 麻烦 的 ,需要 使 用 HTML 编写 一 个 一 
个 的 输入 或 录入 控件 ,还 需要 在 脚本 中 逐一 获取 页 面 的 Request 参数 值 ,而 在 ASP . NET rh, 
微软 公司 创造 性 地 使 用 可 视 化 控件 技术 制作 网 页 ,技术 门槛 低 、 开 发 速度 快 。 

本 任务 使 用 ASP . NET 常用 控件 实现 注册 功能 ,常用 控件 包括 TextBox, Label, Button , 
DropDownList , RadioButtonList , CheckBoxList 等 控件 。 本 任务 只 是 页 面 设计 和 制作 ,注册 实际 
还 需要 把 注册 的 数据 保存 到 数据 库 , 这 里 不 涉及 ,在 后 续 项 目 中 才 会 讲解 到 。 


【基础 知识 】 

1，Web 服务 器 控件 

Web 服务 器 控件 是 指 运行 在 服务 器 端 并 将 实际 内 容 呈 现在 浏览 器 的 .NET 类 。Web 服 
务 器 控件 除了 提供 HTML 服务 器 的 功能 外 ,还 提供 如 下 功能 。 

(1) 功能 丰富 的 对 象 模型 ,该 模型 具有 类 型 安全 编程 功能 。 

(2) 对 于 某 些 控件 ,可 以 使 用 Templates 定义 自己 的 控件 布局 。 

(3) 支持 主题 ,可 以 使 用 主题 为 站 点 中 的 控件 定义 一 致 的 外 观 。 

(4) 可 将 事件 从 嵌 套 控件 传递 到 容器 控件 。 

Web 服务 器 控件 具有 一 些 公 共 属 性 ,比如 字体 .颜色 .样式 等 ,这 些 公 共 属 性 主要 如 
表 4-1 所 示 。 


表 4-1 Web 服务 控件 公共 属性 


名 称 说 — HH 
AccessKey 控件 的 快捷 键 
Attributes 控件 上 未 有 公共 属性 定义 但 仍 需 呈现 的 附加 属性 集合 
BackColor 控件 的 背景 色 


BorderColor 控件 的 边框 颜色 
BorderWidth 控件 边框 的 宽度 (前 提 是 有 边框 ) 
控件 的 边框 样式 (前 提 是 有 边框 ) ,可 能 的 值 包括 NotSet , None , Dotted , Dashed , Solid , 


ЗУ Double, Groove ,Tidge Inset #1 Outset 

cssClass 分 配给 控件 的 级 联 样式 表 ( CSS) 类 

Sytle 作为 控件 的 外 部 标记 上 的 CSS 样式 属性 呈现 的 文本 属性 集合 
Enabled 当 此 属性 设置 为 rwe 时 ,控件 起 作用 ,默认 值 为 ue 
EnableTheming | 当 此 属性 设置 为 rue 时 ,对 控件 启用 主题 

Font 控件 的 字体 信息 

ForeColor 控件 的 前 景色 

Hight 控件 的 高 度 

Skinld 要 应 用 的 控件 的 外 观 

TabIndex 控件 Tab 键 的 顺序 位 置 
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名 称 说 明 
ToolTip 当 用 户 将 鼠标 指针 定位 在 控件 上 方 时 显示 的 文本 
Width 控件 的 宽度 


2. 常用 的 标准 控件 

标准 服务 器 控件 在 ASP . NET 内置 框架 之 中 是 预先 定义 的 ,而 且 大 部 分 都 是 非 复合 控 
件 .最 为 常用 的 控件 。 标 准 控件 在 Visual Stuido 2010 的 工具 箱 中 ,打开 Visual Studio 工具 
箱 ,默认 打开 的 就 是 标准 服务 器 控件 ,如 图 4-1 所 示 。 


-1 - Microsoft Visual Studio (EFE) s[g x 
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图 4-1 工具 箱 中 的 标准 控件 


所 有 控件 的 使 用 都 很 简单 , 即 把 它 从 工具 箱 中 拖 入 页 面 的 设计 视图 中 ,或 是 在 页 面 的 设 
计 视 图 中 选中 位 置 ,在 工具 箱 中 双击 要 使 用 的 控件 。 

知识 链接 : 使 用 控件 可 以 快速 设计 制作 网 页 ,但 是 默认 的 网 页 呈现 效果 不 是 很 理想 。 
如 果 想 设计 漂亮 的 网 页 ,还 需要 学 习 CSS 知识 ,本 书 不 涉及 这 部 分 知识 。 

3. Label 控件 

Label 控件 在 Web 应 用 的 下 列 情况 中 使 用 : 

(1) 希望 显示 的 文本 不 能 被 用 户 更 改 。 

(2) 当 触 发 事件 时 能 够 在 运行 时 更 改 。 

在 通常 情况 下 ,Label 控件 是 不 被 引用 的 ,很 多 程序 员 不 修改 其 ID 是 一 个 错误 的 习惯 ; 
为 了 系统 的 维护 , 需 遵 循 良好 的 命名 规范 。 本 书 为 了 学 生 学 习 方便 ,很 多 控件 的 ID 都 采用 
系统 默认 ,这 样 可 以 减少 学 习 的 难度 ;但 是 不 符合 命名 规则 ,因此 请 学 生 在 熟悉 技术 后 ,自觉 
培养 良好 的 习惯 。 

小 提示 : 良好 的 编程 习惯 是 根据 意义 给 每 一 个 对 象 命名 。 
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开发 过 程 中 ,如 果 只 是 为 了 显示 文本 或 是 HTML 静态 效果 ,不 推荐 使 用 Lable 控件 , 因 
为 服务 器 控件 过 多 会 导致 性 能 问题 。 可 以 考虑 使 用 静态 的 HTML, 因为 这 样 页 面 解析 速度 
更 快 ,效率 更 高 。 

小 提示 : 静态 内 容 效 率 明 显 高 于 动态 内 容 。 

4. TextBox 控件 

在 Web 应 用 程序 中 ,通常 需要 和 用 户 进行 交互 ,这 也 是 动态 和 静态 的 主要 区 别 , 这 时 就 
需要 TexBox( 文 本 框 ) 控 件 , 文 本 框 控 件 是 在 动态 交互 时 ,也 是 整个 Web 应 用 中 使 用 最 为 频 
繁 的 一 个 控件 。 

文本 框 控件 的 主要 属性 如 表 4-2 所 示 。 


表 4-2 文本 框 控件 主要 属性 


名 Ж 说 明 名 Ж 说 — BJ 
AutoPostBack 在 文本 修改 以 后 ,是 否 自动 重 传 | Rows 作为 多 行文 本 框 时 所 显示 的 行 数 
Columns 作为 多 行文 本 框 时 所 显示 的 列 数 | TextMode 文本 框 的 模式 
MaxLength 用 户 输入 最 大 字符 数 Wrap 是 否 换行 
ReadOnly 是 否 为 只 读 


在 关键 属性 中 TextMode 是 需要 特别 注意 的 , TextMode 的 值 有 3 个 : SingleLine、 
MultiLine 和 Password , 即 单行 .多 行 和 密码 ,分别 对 应 HTML 中 text ,textarea , 即 普通 文本 框 、 
文本 区 域 和 密码 输入 框 。 

小 提示 : 密码 输入 框 一 定 要 设置 TextMode 属性 值 为 Password ,否则 不 安全 。 

AutoPostBack 属性 默认 为 false, 如 果 设 置 为 true, 则 控件 被 修改 会 使 页 面 自动 发 回 到 服 
务 器 。 

5. Button 控件 

数据 录入 完 后 , 想 要 把 数据 提交 到 服务 器 ,常常 需要 Button ( 按钮 ) 控 件 ,Button 控件 能 
够 触发 事件 将 网 页 中 的 信息 回 传 给 服务 器 。 

Button 控件 主要 有 3 个 属性 : 

(1) Causes Validation ,按钮 是 否 导致 激发 验证 检查 ; 

(2) CommandArgument ,与 此 按钮 相关 的 命令 参数 ; 

(3) ValidationGroup ,使 用 该 属性 可 以 指定 单 击 按钮 时 调用 页 面 上 的 那些 验证 程序 。 

Button 的 主要 事件 是 Click 事件 ,一 般 页 面 上 都 会 有 一 个 或 多 个 Button ,需要 在 Button 
的 Click 方法 中 写 代码 ,以 实现 单 击 按钮 之 后 的 程序 处 理 。 

6. DropDownList 控件 

DropDownList 控件 为 用 户 提供 多 个 选项 ,要 求 用 户 从 选项 中 选择 其 中 一 项 ,这 样 能 避免 
用 户 输入 错误 的 数据 ,为 程序 的 后 续 处 理 提供 一 致 数据 。 

DropDownList 的 选项 可 以 是 静态 的 ,也 可 以 是 动态 的 ,静态 的 是 指 在 程序 运行 前 选项 已 
经 编写 好 了 ,动态 是 指 在 程序 运行 时 ,选项 还 没有 确定 ,在 使 用 下 拉 框 时 , 才 确 定 其 选项 。 男 
外 DropDownList 的 值 可 以 在 页 面 上 设置 好 ,也 可 以 从 后 台 读 取 ， 比如 从 数据 库 读 取 ， 然后 在 
页 面 上 显示 出 来 。 
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DropDownList 控件 的 常用 属性 如 表 4-3 所 示 。 
#43 DropDownList 控件 的 常用 属性 


名 Ж 说 明 
Items 获取 或 设置 DropDownList 控件 项 的 集合 ,每 一 项 都 是 一 个 Listltem 对 象 
Selected 表示 某 个 选项 是 否 被 选中 
SelectedIndex 获取 DropDownList 控件 被 选中 项 的 索引 值 
Selectedltem 获得 DropDownList 控件 选中 的 项 ,是 一 个 Listltem 对 象 
SelectedValue 获得 DropDownList 控件 被 选中 的 值 


获取 DropDownList 控件 用 户 选 中 值 使 用 DropDownList. SelectedValue 即 可 。 

小 提示 : 实际 项 目 中 ,DropDownList 的 数据 大 多 是 从 数据 库 读 取 的 ,优点 是 灵活 且 易 维护 。 

7. RadioButtonList 控件 

RadioButtonList 控件 也 是 一 种 供用 户 选 择 选 项 的 控件 ,也 是 一 次 只 能 选择 一 项 ,其 选项 
也 是 Listltem 对 象 , 除外 观 和 DropDownList 控件 差别 很 大 之 外 , 其 内 容 和 使 用 与 
DropDownList 控件 基本 相同 。 

8. CheckBoxList 控件 

CheckBoxList 控件 和 RadioButtonList 控件 在 显示 形式 上 基本 相同 ,是 指 在 选项 前 的 选择 框 
一 个 是 方 框 一 个 是 圆 形 的 。 其 选项 也 是 Listltem 的 一 个 集合 ,这 点 和 DropDownList 以 及 
RadioButtonList 都 是 一 样 的 。 不 同 的 是 CheckBoxList 控件 可 以 多 选 ,因此 获取 用 户 选择 项 的 
代码 差别 很 大 。 如 果 使 用 CheckBoxList，SelectedValue 获取 的 是 用 户 选 中 的 第 一 项 ,如 果 用 
户 选中 的 是 多 项 , 则 第 一 项 之 后 的 所 有 选项 选中 的 值 无 法 获取 ,因此 要 想 获取 CheckBoxList 
控件 的 用 户 选 择 值 ,必须 使 用 循环 ,一 个 选项 一 个 选项 地 判断 用 户 是 否 选 择 , 具 体 获 取 值 的 
方法 参见 任务 实施 过 程 。 

知识 链接 : 除了 上 述 控 件 外 ,还 有 很 多 控件 ,比如 RadioButton , CheckBox „ListBox , Panel 、 
HyperLink 等 控件 ,由 于 使 用 频率 远 小 于 上 述 几 种 且 使 用 特别 简单 ,因此 不 再 详细 介绍 ,有 兴 
趣 的 读者 可 以 从 网 上 搜索 。 


【任务 实施 】 

小 提示 : 任务 实施 过 程 主要 掌握 拖 放 控 件 , 修 改 控 件 的 属性 ,编写 简单 事件 代码 。 

第 1 步 新建 网 站 chap4-1 ,添加 新 项 < Web 窗 体 ” ,使 用 默认 名 Default. aspx ,把 Default. 
aspx 由 源 代码 视图 切换 到 设计 视图 。 

第 2 步 ”选择 “ 表 ”"1“ 插 入 表 " 菜 单 命令 ,操作 如 图 4-2 所 示 。 

第 3 步 ” 在 弹出 的 “插入 表格 "窗口 中 ,设置 表格 的 属性 , 行 数 为 “12” , 列 数 为 “3”, 对 齐 
方式 为 “居中 ” ,宽度 为 “500 像素 ” ,效果 如 图 4-3 所 示 ,设置 结 束 后 , 单 击 “ 确 定 ” 按 钮 ,会 在 
设计 视图 中 插入 表格 。 

第 4 步 ” 拖 放 控 件 到 页 面 中 刚 插入 的 表格 里 , 拖 放 的 控件 有 Label .TextBox .DropDownList、 
RadioButtonList ,CheckBoxList 和 Button 控件 , 拖 放 控 件 后 的 效果 如 图 4-4 所 示 。 

第 5 步 ” 对 最 上 端的 Label 控件 设置 属性 ,选中 Label 控件 , 右 击 ,从 弹出 的 快捷 菜单 中 
选择 “属性 "命令 ,如 图 4-5 所 示 。 
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图 4-2 插入 表 操 作 界面 
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图 44 放 入 控件 的 页 面 效 果 


小 提示 : 如 果 “ 属 性 ”窗口 已 经 打开 , 则 选中 控件 ,打开 “属性 "窗口 即 可 。 
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图 4-5 设置 Label 属性 


第 6 步 TE Label 的 属性 窗口 中 ,对 Label 的 Text 属性 进行 设置 ,设置 为 "用户 注册 ”， 
如 图 4-6 所 示 。 

第 7 步 与 第 一 个 Label 控件 设置 相同 ,对 其 他 Label 控件 进行 设置 ,根据 页 面 显示 需 
要 设置 其 他 Label 的 Text 属性 。 

第 8 步 ” 对 第 一 个 TextBox 设置 属性 ,把 第 一 个 TextBox 控件 的 ID 属性 设置 为 
tbxUserName ,如 图 4-7 所 示 。 

第 9 Ж ”和 第 一 个 TextBox 控件 的 属性 设置 相同 ,设置 其 他 TextBox 控件 ,根据 实际 意 
义 命名 。 

第 10 步 设置 网 页 上 唯一 的 一 个 RadioButtonList 控件 , 单 击 RadioButtonList 控件 右上 
方 的 ” > "符号 ,弹出 “RadioButtonList 任务 "窗口 ,如 图 4-8 所 示 。 

第 11 步 单 击 “RadioButtonList 任务 "窗口 中 的 “编辑 项 "按钮 ,打开 “ListItem нн 
器 ”窗口 ,添加 两 项 : 男 、 女 ,并 修改 其 Text 和 Value 值 , 如 图 4-9 所 示 。 单 击 “ 确 定 ” 按 
RadioButtonList 控件 中 就 有 了 选项 。 

第 12 步 设置 网 页 上 唯一 的 一 个 DropDownList 控件 , 单 击 DropDownList 控件 右上 方 的 
“> ”符号 ,弹出 DropDownList 任务 "窗口 , 单 击 “ DropDownList 任务 "窗口 中 的 “编辑 项 ” 按 
钮 ,打开 “Listltem gp vii H d 3 项 : 研究生、 本 科 、 专 科 , 并 修改 其 Text 和 Value 
值 ,如 图 4-10 所 示 。 单 击 “ 确 定 ” 按 
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Labell System.Web.UI.WebControls.Label - tbxUserName System.Web.ULWebControls.Tey ~ 
SB ET РЕ ss, |a= 
BorderColor ^ (Expressions) = 
BorderStyle NotSet tbxUserName 
BorderWidth AccessKey 
ClientIDMode Inherit AutoCompleteType None 
CssClass a AutoPostBack False 
Enabled True BackColor L 
EnableTheming True BorderColor 
EnableViewState True BorderStyle NotSet 
b Font BorderWidth 
ForeColor CausesValidation False 
Height š ClientlIDMode Inherit 
SkinID Columns 0 
Tabindex 0 CssClass 
用 户 注 册 Enabled True 
ToolTip EnableTheming True 
ViewStateMode Inherit EnableViewState True 
Visible True b Font 
Width Е ForeColor - 
Text aD) 
为 标签 显示 的 文本 。 此 控件 的 编程 名 称 。 
图 4-6 Label 控件 的 Text 属性 设置 图 4-7 TextBox 的 ID 属性 设置 


оо chap4-1 - Microsoft Visual Studio( 管 理 员 ) 
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图 4-8 设置 RadioButtonList 控件 选择 项 


图 4-10  Listltem 集合 编辑 器 


小 提示 : 下 拉 框 等 控件 的 选项 可 以 静态 编辑 ,也 可 以 动态 编程 实现 ,参考 本 任务 拓展 
提高 。 

第 13 步 设置 网 页 上 唯一 的 一 个 CheckBoxList 控件 , 单 击 CheckBoxList 控件 右上 方 的 
“> "符号 ,弹出 “CheckBoxList 任务 "窗口 ,如 图 4-11 所 示 。 

5 14 32 E" CheckBoxList 任务 "窗口 中 的 “编辑 项 "按钮 ,打开 “Listltem 集合 编辑 
器 ”窗口 ,添加 5 项. 读书 .音乐 .打球 ,旅游 上 网 ,并 修改 其 Text 和 Value 值 ,如 图 4-12 所 
m. ubt" TEL, 

第 15 步 ”设置 Button 控件 属性 。 把 网 页 上 唯一 的 Button 控件 的 Text 属性 设置 为 “ 注 
册 ”。 网 页 设置 全 部 完成 ,设置 好 的 网 页 效果 如 图 4-13 所 示 。 

第 16 步 "Hu" HE" Button 控件 ,进入 Buttonl_Click 事件 ,此 事件 在 Default. aspx. cs 
文件 中 ,如 图 4-14 所 示 。 
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图 4-11 CheckBoxList 控件 编辑 项 
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图 4-12 Listltem 集合 编辑 器 
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图 4-13 属性 设置 后 的 页 面 
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using System. Veb. UI 
using System. Veb, UI. WebControls; 


Epublic partial class Default : System. Veb, UL. P: 


u BESEXZC 


© protected void Page_Load(object sender, Everthres e) 
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图 4-14 ”注册 按钮 事件 方法 


第 17 步 ”在 事件 protected void Button1_Click(object sender, EventArgs e) | | 中 ,录入 
按钮 处 理事 件 代码 ,代码 如 下 。 注 意 ,为 了 读者 看 得 明白 ,此 处 把 事件 名 称 Button1_Click 也 
带 上 去 了 。 


protected void Buttonl Click (dbject sender, EventArgs e) 

{ 
Respcnse.Write(" 你 的 姓名 : "+this.tbwUserName.Text +" «br >"); 
Response.Write(" 你 的 密码 : " +this.thxPassword. Text +" «br >"); 
Response.Write ("你 的 确认 密码 : "Hthis.tbxPassword2 .Text +" «br >"); 
Response.Write ("你 的 真实 姓名 : " +this.thxRealNeme.Text +" <br >"); 
Response Write ("你 的 性 别 : " +this rb1Sex.SelectecValue +" «br >"); 
Response Write ("你 的 年 龄 : " +this.thxAg.Text +" «br >”); 
Response. Write ("你 的 Email: "4this.tbxEmail.Text +" <br >”); 
Response Write ("PRÁ QQ: " 4this.tb»xQO. Text +" <br >”); 
Response. Write ("你 的 学 历 : " 4this.ddlDsgree..Selectedvalue +" «br >"); 
Response.Write ("你 的 爱好 : "); 
foreach (ListItem item in this.cblictby.Items) 


{ 
if (item.Selected --true) 
{ 
Response.Write (item.Value +","); 
} 
} 


} 
第 18 步 ”启动 调试 ,页 面 运行 效果 如 图 4-15 所 示 。 
第 19 步 ”在 网 页 上 录入 相应 内 容 , 单 击 “ 注 册 ” 按 钮 ,在 页 面 上 输出 录入 的 信息 ,运行 
效果 如 图 4-16 所 示 。 
. 89 . 


D localbost7453/chap4-1, x Ed 
> © |[localhost:7453/chap4-1/Default1.aspx 


图 4-15 ”页 面 运行 效果 


Q: 234567876 
你 的 学 历 ， 研 究 生 
你 的 爱好 ， 音乐 ,旅游 上网， 


图 4-16 页 面 运行 效果 


【任务 小 结 】 

本 任务 介绍 了 使 用 常用 的 标准 服务 器 控件 设计 制作 * 注 册 ” 网 页 的 过 程 ,并 实现 了 用 户 
录入 数据 后 在 网 页 上 输出 用 户 录入 信息 的 功能 。 使 用 到 的 技术 主要 包括 常用 控件 ， 
TextBox, Label, Button, DropDownList, RadioButtonList 和 CheckBoxList 以 及 内 置 对 象 
Respose 等 。 

【 拓展 提高 】 

1. 联动 下 拉 框 

制作 两 个 下 拉 框 ,第 一 个 下 拉 框 是 省 份 ,第 二 个 下 拉 框 是 城市 , 当 第 一 个 下 拉 框 选中 某 
一 个 省 份 时 , 则 在 第 二 个 下 拉 框 中 显示 出 选中 省 份 的 城市 。 
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第 1 步 在 网 站 chap4-1 中 ,添加 新 项 Web. 窗 体 Defauli2. aspx。 向 网 页 中 拖 放 两 个 
Label 控件 和 两 个 DropDownList 控件 ,效果 如 图 4-17 所 示 。 


图 4-17 放 入 控件 的 页 面 


第 2 步 设置 Label 控件 的 Text 属性 分 别 为 “省 份 " 和 “城市 ” ,设置 第 一 个 DropDownList 
控件 , 即 在 “省 份 "控件 后 边 的 下 拉 框 ,为 其 编辑 项 : 河南 .河北 山东 ,效果 如 图 4-18 所 示 。 
Tour = - 
5. De 


图 4-18 设置 属性 后 页 面 


第 3 步 ” 设 置 “ 省 份 ” DropDownList 控件 的 AutoPostBack 属性 值 为 “true” ,效果 如 
图 4-19 所 示 。 

第 4 步 单 击 “ 属 性 ”窗口 上 部 的 区 | 按钮 ， 打开 下 拉 框 的 事件 窗口 ,双击 SelectedIndex- 
Changed 后 边 的 录入 框 ,如 图 4-20 所 示 。 


(Expressions) 
(D) DropDownListl 
AccessKey 
AppendDataBoundl! False 
E True 


AutoPostBack 
BackColor 
CausesValidation False 
ClientIDMode Inherit 


4-19 设置 AutoPostBack 属性 


CssClass 
DataMember 
DataSourcelD 
DataTextField 
DataTextFormatStrin 
DataValueField 
Enabled True 
EnableTheming True 属性 -ax 
EnableViewState True DropDownList] System. Web.UI.WebControls.t = 
b Font —À 
g "m 
ForeColor m Ш>] = 
Height end 
Item: 'ataBoun 
= жа) Disposed 
SkinID ik 
TabIndex 0 tosd 
ToolTip PreRender 
ValidationGroup [l 
ViewStateMode Inherit TextChanged || 
Visible True Unload 
Width 
SelectedIndexChanged 
在 更 改选 定 索引 后 激发 。 


图 4-20 设置 SelectedIndexChanged 事件 
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小 提示 :“ 属 性 "窗口 中 有 4 个 按钮 : 按 类 型 排列 、 按 字母 排列 、 属 性 事件。 读者 可 以 
单 击 试 试 。 
第 5 步 ”双击 后 ,进入 DropDownListl SelectedIndexChanged 方法 ,编写 代码 ,代码 如 下 。 


protected void DropDownListl SelectedIndexChanged (object sender, EventArgs е) 
{ 
if (province = 一 河南 由 
( 
this.DropDownList2 .Items.Clear () ; 
this.DrogDownlist2 . Items Act (new ListItem ("Э ", "ХИН ) ; 
this.DrocDownList2 . Items Act (new ListItem ("Z PA", "ZA" ); 
this.DropDownList2 .Ttems Ac (new ListTtem("fri BA", Ч"); 
) 
else if (province ==" 河 北 ") 
{ 
this.DropDownList2.Items.Clear () ; 
this.DrocDownList2 . Items Ac (new ListItem ("£1 RE", "BW E"); 
this.DropDownList2 .Ttems Ac (new ListItem(" [GE ", ЧЕ"); 
this.DrogDowriList2 Тепе Ac (new ListTtem("HBAfB ", "ШЇ ")); 


this.DropDownList2 .Tteme Clear () ; 

this.DropDownList2.Ttems Act (new ListItem ("UE Ri ", "济南 ")); 

this.DropDownList2.Ttems Act (new ListItem ("ff 8j ", "青岛 ")); 

this.DropDownlist2 . Items Act (new ListTtem ("BI ", "lio ) ; 
) 


第 6 步 。 启动 调试 ,打开 网 页 中 ,省 份 下 拉 框 显示 的 是 河南 ,城市 下 拉 框 中 没有 数据 ,页 
面 运行 效果 如 图 4-21 所 示 。 


[DD localhost:7453/chap4-1, x V — 
€ > С |[localhost:7453/chap4-1/Default.aspx 


省 份 。 [河南 "| 
Wo. [v] 


图 4-21 页 面 运行 效果 


第 7 步 ”选中 "省份 "下 拉 框 中 的 “山东 ”项 , 则 ”城市 "下 拉 框 中 会 出 现 * 济 南 "“ 


д 
E 
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和 ”聊城 "3 个 城市 项 ,页 面 运 行 效果 如 图 4-22 所 示 。 


图 4-22 ”页 面 运 行 效果 


第 8 步 ” 选 中 “省 份 " 下 拉 框 中 的 “河南 ”项 , 则 “城市 "下 拉 框 中 会 出 现 “ 郑 州 "“ 安 阳 ” 
和 “信阳 ”3 个 城市 项 ,页 面 运 行 效果 如 图 4-23 所 示 。 


D localhost7453/chap4-1 x Ü 3 › 
€ > C |[localhost7453/chap4-1/Default.aspx 


河南 "| 
郑州 v 
安阳 


信阳 


图 4-23 页面 运行 效果 


2. Button 按钮 

ASP . NET 总 Button 控件 允许 用 户 通过 单 击 来 执行 操作 ,除了 Button 标准 命令 按钮 ) 
控件 外 ,还 有 两 个 按钮 控件 LinkButton 与 ImageButton。 

Button 控件 是 一 个 Submit 按钮 ,控件 显示 为 按钮 形状 且 在 按钮 上 显示 文本 ,LinkButton 
显示 为 超 链 接 样 式 ,ImageButton 显示 为 图 形 样式 ,但 是 功能 没有 区 别 。 

LinkButton 与 ImageButton 控件 如 表 4-4 所 述 。 


表 4-4 ”按钮 控件 
名 Ж 说 明 
LinkButton 显示 为 页 面 中 的 一 个 超 链 接 , 包 含 使 窗 体 被 发 回 服务 器 的 客户 端 脚本 
ImageButton 将 图 形 呈 现 为 按钮 ,并 提供 了 有 关 图 形 内 已 单 击 位 置 的 坐标 信息 


3. 用 户 自 定义 控件 
用 户 自 定义 控件 就 是 封装 ASP . NET 提供 的 内 置 控件 形成 的 控件 ,或 是 把 ASP . NET [8] 
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有 的 控件 复合 在 一 起 ,就 形成 了 用 户 自 定义 控件 。 

用 户 自 定义 控件 提供 了 一 种 模块 化 Web 应 用 程序 的 方法 , 复 用 性 提高 ,可 重用 性 以 及 
可 维护 性 都 得 到 增强 。 

用 户 控件 的 创建 和 Web 窗 体 基本 相同 ,只 是 用 户 控件 是 以 . ascx 作为 扩展 名 ,用 户 控件 
的 设计 和 Web 窗 体 是 一 致 的 。 

用 户 控件 创建 好 以 后 ,需要 先 注 册 , 再 放置 。 在 Visual Stuido 2010 中 ,只 需 把 用 户 控件 
直接 拖 放 到 Web 窗 体 中 ,注册 、 放 置 同时 完成 ,简单 高 效 。 

用 户 控件 是 需要 在 设计 整个 应 用 综合 考虑 的 ,在 学 习 初 期 不 建议 花费 太 多 时 间 和 精力 
在 用 户 控件 上 。 

4. 文件 上 传 

文件 上 传 是 很 多 系统 都 要 使 用 的 一 个 功能 ,在 ASP .NET 中 ,客户 端 使 用 FileUpload 
控件 实现 文件 的 上 传 ,在 服务 器 端 使 用 SaveAs 方法 把 客户 端 上 传 的 文档 保存 到 服务 器 。 

文件 的 上 传 涉及 10 操作 ,比如 在 目录 不 存在 的 情况 下 需要 创建 目录 ,以 及 文件 的 创建 
和 删除 等 ,但 是 在 ASP . NET 中 已 经 最 大 限度 地 封装 底层 ТО 操作 ,开发 人 员 可 以 轻松 简单 
地 实现 文件 上 传 功能 。 

第 1 步 在 网 站 chap4-1 中 ,添加 新 项 Web 窗 体 Default3. aspx 

第 2 步 在 网 页 Defauli3. aspx 中 输入 “文件 1” 和 “文件 2" 文 本 内 容 , 再 拖 入 两 个 
FileUpload 控件 和 一 个 Button. 控件 ,修改 Button 控件 的 Text 属性 为 “上 传 文件 ”。 如 
图 4-24 所 示 。 


图 4-24 网 页 设计 效果 


第 3 步 单 击 Default3. aspx 下 的 “ 源 ” ,切换 到 源 视图 ,在 源 代码 中 找到 < form > 标签 ， 
给 <form > 标签 添加 属性 enctype =" multipart/form-data" , 源 代码 如 图 4-25 所 示 。 

小 提示 : 属性 enctype = " multipart/form-data" 是 必须 添加 的 ,如 果 不 添加 , 则 文件 不 发 送 
到 服务 器 ,发 送 到 服务 器 的 是 字符 串 而 不 是 文件 ,当然 也 就 无 法 实现 文件 上 传 功 能 。 

第 4 步 ”在 网 站 chap4-1 中 添加 文件 夹 。 右 击 chap4-1, 从 弹出 的 快捷 菜单 中 选择 “新 
建文 件 夹 "命令 ,如 图 4-26 所 示 。 

第 5 步 ” 修 改 文 件 夹 名 称 为 upload ,如 图 4-27 所 示 。 

第 6 步 ” 网 页 Default3. aspx 切换 到 “设计 视图 ” ,双击 “上 传 文件 "按钮 ,进行 Buttonl 
Click 事件 ,在 该 事件 中 编写 如 下 代码 : 
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"http://www. v3. org/ 1999/xhtn1"» 
erver^) 
Ctitlex</tit1e> 
</head> 
<form id="foral” runat="server" enctype="multipart/fora-data”》 
<div> 


文件 1: <asp:FileUpload ID-FileUploadl" runat="server" /> 

br /> 

文件 2: <asp:FileUpload ID="FileUpload2" runat="server" /> 

br /> 

Kasp:Button ID="Buttonl” runat="server" onclicke"Buttonl Click" Textz" E f& Ж” /» 


divy 

Хота 
[wbody> 
«Ааа. 

oo% ~ «| 


ше | 口 拆 分 ый 


Fpublae partial class D. 


protected void Page. Loa 


1 


《IDOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN "http://www. w3. org/TR/xhtnll/DID/xhtnll-tran. 


Үр ected void Buttonl, | 添加 ASP.NET 文件 突 (9) 
HttpFileCollection EBED. Ë = UMS 
foire Gre = жш Web 引用 中- E falces 


EREA.. 
жгт 
имир) 
BIERO. 
REWER 
GAME) 


L Weste 
Filol 


ж 
postedFil 


ё 2 


Eiuuxibox-rüH b 


[d BE "chap4-1" (1 个 项 目 ) 
4 @ dAnetworkychap4-1N 


Га upload 

ЇЗ] Default.aspx 

£3] Default1.aspx 

[E] Default3.aspx 

[ upload35.0.1916.153. manifest 
回 uploaddelegate execute.exe 
lily web.config 

图 Web.sitemap 


图 4-26 ”添加 文件 夹 
for (int iFile -0; iFile «files.Count; iFile ++) 
{ 
HttpPostedEile postedFile —files[iFile]; 
string fileName -postedkile.FileName.Substring (postedEile.FileName. 
IastindexOf ("NV") +1); 
postedEile.SaveAs (Server .MapPath (" ~ /upload/") *fileName); 
Response Write (postedFile.FileName +" 上 传 成 功 I" a" «br >"); 


图 4-27 upload 文件 夹 
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知识 链接 : 代码 HttpFileCollection files = HttpContext. Current. Request. Files 的 作用 是 获 
取 网 页 提交 的 文件 ;postedFile. SaveAs 的 作用 是 保存 文件 ;Server. MapPath(" ~ /upload/" ) 
的 作用 是 把 网 站 中 的 upload 目录 映射 为 物理 地 址 。 

代码 编辑 好 后 ,效果 如 图 4-28 所 示 。 


3 Default3 ~| i$ Button1_Click(obji 
Busing System; 


using Systen. Collections. Generic; 
using Systen. Linq: 

using System. Web: 

using System. Web. UI: 

using System. Web. UI. VebControls: 


日 public partial class Default3 : System. Web. UI. Page 
t 


protected void Page Load(object sender, 
t 


entArgs e) 


1 
Gh protected void Buttonl Click(object sender, Eventárgs e) 
t 


| HttpFileCollection files = HttpContext. Current. Request. Files; 
| for(int iFile = 0; iFile < files.Count; iFile++) 
| t 


HttpPostedFile postedFile = files[iFile]; 


string fileName = postedFile.FileName. Substring (postedFile. FileName, LastIndexOf (V) + 1); 
postedFile. SaveAs (Server. KapPath(^ "/upload/^) + fileName): 
Response. Vrite(postedFile.FileName + ”上 传 成 功 ” + “<br>"); 


图 4-28 文件 上 传代 码 


第 7 步 在 Visual Stuido 2010 中 打开 Default3. aspx 或 Default3. aspx. cs 的 前 提 下 ,启动 
调试 。 网 页 运行 效果 如 图 4-29 所 示 。 


20| х J 


Qo Ө посока Ф P ~ Вох] Ә canos х |а $$ & 


文件 1: Ermm] 
文件 2: WR... 


图 4-29 网 页 运行 效果 


第 8 步 单 击 “ 选 择 文件 " ,弹出 选择 文件 对 话 框 ,选择 文件 ,两 个 文件 都 选择 好 后 ,页 
面 效果 如 图 4-30 所 示 。 


ole] x 
(< obs P - вех || аһ xa] оу 


文件 1: C:\Program Files (х86)6 (Б а) 
X2: C:Wsers\AdministratoriD 


图 4-30 选中 文件 
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第 9 步 单 击 * 上 传 文件 "按钮 ,文件 上 传 成 功 ,页 面 效 果 如 图 4-31 所 示 。 


@ hspi/localhost7a Ф D ~ Ë Ó X 


CiProgram Files (x86) Google!Chrome'Application'chrome.exe 上 传 成 功 
CaAUsers\AdministratoriDesktop 第 七 章 AJAX doc 上 传 成 功 


文件 1: жй... 


文件 2: С...) 


Р 4-31 上 传 成 功 


任务 4-2 使 用 验证 控件 验证 注册 数据 


【任务 描述 】 

小 王 开 发 好 应 用 程序 后 , 交 给 用 户 使 用 。 在 使 用 过 程 中 用 户 很 不 满意 ,很 多 网 页 上 ,用 
户 录入 的 数据 有 问题 也 能 执行 ,结果 把 很 多 错误 的 .不一致 的 数据 保存 到 了 数据 库 , 给 后 续 
工作 带 来 了 很 多 麻烦 。 

比如 注册 页 面 ,用 户 没有 录入 密码 ,没有 填写 E-mail 或 明显 不 是 E-mail 的 信息 都 能 保 
存 到 数据 库 , 因 此 客户 公司 让 小 王 加 班 加 点 尽早 解决 这 个 问题 。 

【任务 目的 】 

(1) 掌握 验证 控件 的 概念 。 

(2) 掌握 RequiredFieldValidator 控件 在 验证 数据 时 的 使 用 。 

(3) 掌握 CompareValidator 控件 在 验证 数据 时 的 使 用 。 

(4) 掌握 RangeValidator 控件 在 验证 数据 时 的 使 用 。 

(5) 掌握 RegularExpressionValidator 控件 在 验证 数据 时 的 使 用 。 

(6) 了 解 CustomValidator 和 ValidationSummary 控件 在 验证 数据 时 的 使 用 。 


【任务 分 析 】 

数据 验证 可 以 分 为 客户 端 验证 和 服务 器 端 验证 ,客户 端 验证 一 般 使 用 JavaScript ВЕЖ; 
服务 器 端 验证 一 般 采 用 相应 的 高 级 语言 。 数 据 验证 工作 繁琐 复杂 ,需要 写 很 多 代码 ,使 很 多 
程序 员 感 到 枯燥 。 

在 ASP .NET 中 ,使 用 验证 控件 对 数据 验证 进行 了 简化 ,只 需要 在 网 页 中 放 入 几 个 控 
件 ,进行 简单 的 设置 ,就 能 完成 绝 大 多 数 的 验证 工作 。 

【基础 知识 】 

1. 验证 控件 

小 提示 : 企业 开发 中 ,数据 验证 的 作用 举足轻重 , 它 是 应 用 系统 可 靠 性 的 重要 保障 。 

应 用 系统 中 ,用 户 需 要 录入 各 式 各 样 的 信息 ,为 了 系统 的 安全 和 可 靠 ,需要 做 大 量 的 数 
据 验证 。 传 统 的 数据 验证 因 编 写 代码 量 大 而 使 人 诉 病 ,微软 公司 在 ASP . NET 提供 了 验证 
控件 ,这 些 控件 根据 数据 验证 的 规则 简化 数据 验证 。 
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验证 控件 可 以 检查 用 户 输入 ,并 且 在 窗 体 发 送 到 服 тат тех 


务 器 时 进行 验证 ,如 果 输 入 没有 通过 验证 , 则 会 返回 到 | "Pe 
输入 页 面 ,并 在 页 面 中 提示 验证 错误 。 2 


ASP . NET 提供 了 6 种 验证 控件 ,分 别 是 
RequiredFieldValidator 、CompareValidator 、RangeValidator 、 
RegularExpressionValidator , CustomValidator 和 
ValidationSummary 控件 。 这 些 控件 都 在 工具 箱 的 验证 
中 ,如 图 4-32 所 示 。 Pen 

2. RequiredFieldValidator 控件 

RequiredFieldValidator 控件 是 非 空 验证 ,也 就 是 用 | > ААХ Extensions 
户 必须 在 对 应 的 控件 中 输入 数据 ,才能 通过 验证 ， |. m= 
RequiredFieldValidator 控件 的 主要 属性 如 表 4-5 所 示 。 as 


k 
09, CompareValidator 
Ë CustomValidator 
Ë  RangeValidator 
车 
Ey. 
ü 


RegularExpressionValidator 
RequiredFieldValidator 
ValidationSummary 


Display 属性 有 3 个 可 选 值 :None 表示 从 不 内 联 显 一 一 一 一 一 一 一 
示 的 验证 程序 内 容 ;DyNamic 表示 验证 失败 时 动态 添加 | aa R 
到 页 面 中 的 验证 程序 内 容 ;Static 作为 页 面 布 局 的 物理 
组 成 部 分 验证 程序 内 容 , 默 认为 Static。 图 4-32 ”验证 控件 

表 4-5 RequiredFieldValidator 控件 主要 属性 

# Ж 说 明 
VontrolToValidate | 获取 或 设置 要 验证 的 输入 控件 
ErrorMessage 获取 或 设置 验证 失败 时 显示 的 错误 消息 文本 
Display 获取 或 设置 验证 控件 中 错误 消息 的 显示 行为 
IsVlid 获取 或 设置 一 个 值 ,该 值 指示 关联 的 输入 控件 是 否 通过 验证 
SeFOcuOnEso, | 获取 或 设置 一 个 值 , 该 值 指示 在 验证 失败 时 是 否 将 焦点 设置 到 Control To Validate 属 

性 指定 的 控件 上 


3. CompareValidator 控件 
CompareValidator 控件 是 比较 验证 控件 , 它 常常 用 来 把 一 个 控件 的 输入 值 同 另 一 个 控件 
的 输入 值 比较 ,CompareValidator 控件 的 主要 属性 如 表 4-6 所 示 。 
表 4-6  CompareValidator 控件 主要 属性 
名 Ж 说 0 
VontrolToValidate 获取 或 设置 要 验证 的 输入 控件 
ControlToCompare 比较 依据 的 控件 


Operator 获取 或 设置 要 执行 的 比较 操作 

Type 比较 值 的 数据 类 型 

Text 获取 或 设置 验证 失败 时 验证 控件 中 的 显示 文本 

SetFOcusOnError 获取 或 设置 一 个 值 , 该 值 指示 在 验证 失败 时 是 否 将 焦点 设置 到 ControlToValidate 属 
性 指定 的 控件 上 
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CompareValidator 控件 的 Operator 属性 是 一 个 关键 的 属性 , 它 是 采用 什么 方式 比较 的 设 
定 , 它 的 取 值 是 一 个 枚 举 值 ,具体 值 如 表 4-7 Bron o 


#47 Operator 属性 的 取 值 


名 Ж 说 明 
Equal 相等 比较 
NotEqual 不 等 比较 
GreateThan 大 于 比较 


GreateThanEqual 大 于 等 于 比较 


LessThan 小 于 比较 
LessThanEqual 小 于 等 于 比较 
输入 到 所 验证 的 输入 控件 的 值 BaseCompareValidator. Type 属性 指定 的 数据 类 型 


DataTypeCheck 


之 间 的 数据 类 型 比较 


4. RangeValidator 控件 

RangeValidator 控件 检查 用 户 输入 的 范围 , 即 上 限 和 下 限 。 检 查 类 型 是 可 以 按照 数字 、 
字符 串 和 日 期 等 修改 控件 的 大 多 属性 和 CompareValidator 的 控件 类 型 ,不 同 的 是 
RangeValidator 控件 有 两 个 属性 : MaximumValue 和 MinimumValue ,这 两 个 属性 设置 了 验证 
控件 的 最 大 值 和 最 小 值 。 

5. RegularExpressionValidator 控件 

RegularExpressionValidator 控件 检查 字符 串 是 否 符合 正则 表达 式 匹 配 , 通 过 该 控件 ,可 
以 检查 输入 数据 是 否 符合 一 定 的 格式 ,这 在 验证 中 十 分 常见 ,比如 身份 证 号 ,学 号 .电话 号 
码 .邮政 编码 .电子 邮箱 等 ,它们 都 具有 一 个 格式 ,不 符合 格式 要 求 就 一 一 定 是 错误 的 数据 ， 正 
则 表达 式 就 是 处 理 这 一 类 问题 的 。 

在 ASP .NET 中 为 了 开发 方便 ,内 置 了 一 些 常 用 的 正则 表达 式 , 开 发 人 员 只 需 选 中 即 
可 ,不 需要 编写 正则 表达 式 。 

6. CustomValidator 控件 

Custom Validator 控件 是 自 定 义 验证 控件 ,根据 名 称 可 以 知道 ,验证 的 逻辑 是 需要 开发 人 
员 编 写 的 。 该 控件 主要 是 为 了 扩展 验证 控件 , 当 ASP . NET 提供 的 验证 控件 不 能 满足 开发 
人 员 的 需求 时 ,可 以 使 用 它 自 己 编写 验证 。 

该 控件 需要 设置 ClinetValidationFunciton 或 ServerValidate 属性 ,以 验证 工作 是 由 哪个 函 
数 或 方法 完成 ,而 这 个 函数 或 方法 需要 用 户 自己 定义 和 实现 。 

7. ValidationSummary 控件 

ValidationSummary 控件 在 网 页 上 汇总 输出 所 有 验证 控件 的 错误 信息 。ValidationS- 
ummary 控件 的 主要 属性 如 表 4-8 所 示 。 

ValidationSummary 控件 的 DisplayMode 属性 有 3 个 选项 值 : List 用 于 显示 在 列表 中 的 验 
证 摘要 ;BulletList 用 于 显示 在 项 目 符号 列表 中 的 验证 摘要 ;SingleParagraph 用 于 显示 在 单个 
段落 内 的 验证 摘要 。 
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34-8 DisplayMode 属性 的 选项 值 


名 Ж 说 — 明 
DisplayMode 获取 或 设置 验证 控件 摘要 的 显示 模式 
ShowMessageBox 获取 或 设置 一 个 值 ,该 值 指示 是 否 在 消息 框 中 显示 验证 摘要 
ShowSummary 获取 或 设置 一 个 值 ,该 值 指示 是 否 内 联 显示 验证 摘要 


知识 链接 : 验证 的 方式 很 多 ,还 可 以 使 用 JavaScript 进行 验证 。JavaScript 验证 属于 前 台 
验证 ,是 在 网 页 上 直接 执行 的 验证 ,效率 较 高 。 

【任务 实施 】 

第 1 步 ” 新建 空 网 站 chap4-2 ,添加 名 为 Default. aspx 的 Web 窗 体 ,按照 chap4-1 的 步骤 
制作 网 页 ;或 把 网 站 chap4-1 中 的 Default. aspx 复制 到 chap4-2 中 。 

95 2 35 In] Default. aspx 网 页 中 添加 验证 控件 ,添加 的 位 置 是 表格 的 第 三 列 ,添加 后 的 
页 面 效 果 如 图 4-33 所 示 。 

第 3 步 设置 “用 户 名 ”的 验证 控件 属性 ,设置 ControlToValidate 属性 值 为 tbxUserName , 
ErrorMessage 属性 值 为 “请 输入 用 户 名 ”,SetFocusOnError 属性 值 为 True ,如 图 4-34 所 示 。 同 
理 设置 “密码 ”" 和 “姓名 ”的 验证 控件 的 属性 。 


[gie тех 
RequiredFieldValidator1 System.Web.UL.Webt + 
mwm- - EE 
(Expressions) 
00) RequiredFieldValidator1| 
AccessKey 
div BackColor 
=s BorderColor 
用 户 注册 BorderStyle NotSet 
ВРА. 1 RequiredFieldValidator BorderWidth 
密码 ， [ ”RequiredFieldyalidator ClientiDMode Inherit 
SUE. [eo areValidator ControlToValidate  tbxUserName 
4 5 F T CssClass 
姓名 ， [ RequiredFieldValidator Display [T 
EnableClientScript True 
性 别 ， ox Enabled True 


EnableTheming — True 
EnableViewState — True 
ErorMessage 请 输入 用 户 名 
Font 


年 龄 ， [  RangeValidator 
Email [| — "Regul arExpressionVali dator 
QQ: [ "CustonValidator 


| 
| 
сз | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


ForeColor. 
学 | X 
学 历 Гах] Height 
LB InitialValue 
| 口音 乐 SetFocusOnError True 
° SkinID 
兴趣 爱好 ， 口 打球 Tabindex 0 
口 旅游 Text 
гй | чыдоо 
jalidationGroup 
ViewstateMode Inherit 
Visible True 
Width 


ErrorMessage 
当 验 证 的 控件 无 效 时 在 ValidationSummary 中 显示 
的 消息. 


图 4-33 ”网 页 设计 效果 图 4-34 控件 属性 设置 
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第 4 步 设置 “确认 密码 ”的 验证 控件 属性 ,设置 ControlToValidate 属性 值 为 tbxPassword2 , 
ControlToCompare 属性 值 为 tbxPasswrod , ErrorMessage 属性 值 为 “确认 密码 和 密码 必须 相 


同 ”,SetFocusOnError 属性 值 为 True ,如 图 4-35 所 示 。 
设置 “年 龄 ”的 验证 控件 属性 ,设置 ControlToValidate 属性 值 为 tbxAge， 


第 5 步 


ErrorMessage 属性 值 为 “年 龄 必须 在 18 至 60 之 间 ”, SetFocusOnError 属性 值 为 True š 
MaximumValue 属性 值 为 60 ,MinimumValue 属性 值 为 18 ,如 图 4-36 所 示 。 


第 6 步 


设置 *E-mail” 的 验证 控件 属性 ,设置 ControlToValidate 属性 值 为 tbxEamil, 


ErrorMessage 属性 值 为 “E-mail 地 址 不 符合 要 求 ,请 重新 填写 ”, SetFocusOnError 属性 值 为 


True ,如 图 4-37 所 示 。 


属性 x 


CompareValidatorl System.Web.ULWebContr, 
ss |a В 
(Expressions) 
00) CompareValidator1 
AccessKey 
BackColor 
BorderColor 
BorderStyle 
BorderWidth 
ClientIDMode Inherit 
ControlToCompare tbxPassword 
ControlToValidate tbxPassword2 
CssClass 
CulturelnvariantValu False 
Display Static 
EnableClientScript True 
Enabled 
EnableTheming 


NotSet 


Et 
Rangevalidatorl System. Web.ULWebControls. = 


ЭЙ ® 
(Expressions) 
00) 

AccessKey 
BackColor 
BorderColor 
BorderStyle 
BorderWidth 
ClieMIDMode Inherit 
ControlToValidate — tbxAge 
CssClass 
CulturelnvariantValu False 
Display : 
EnableClientScript 
Enabled 

EnableTheming 
EnableViewState 


NotSet 


"әх 属性 


БЕ? [ш 5 
(Expressions) 
(D) 

AccessKey 
BackColor 
BorderColor 
BorderStyle 
BorderWidth 
ClientIDMode 
ControlToValidate 
CssClass 
Display 
EnableClientScript 
Enabled 
EnableTheming 
EnableViewState 
ErrorMessage 


RegularExpressionValidator1 System.Web.UL ~ 


-ex 


RegularExpressionvalid 


NotSet 


Inherit 
tbxEmail 


Static 
True 
True 
True 
True 


Email 地 址 不 符合 要 求 ， 


EnableViewstate 
ErrorMessage 
Font 

ForeColor 
Height 

Operator 
SetFocusOnError 
SkiniD 

Tablndex 


MaximumValue 
MinimumValue 
SetFocusOnError 
SkiniD. 

Tabindex 


ValidationGroup 
ViewStateMode 
Mm 


ValidationGroup 


ValueToCompare Inherit 
mE 


SetfocusOnError Теше 
SkinID 

Tabindex 0 
Text 

ToolTip 


ValidationGroup 
ViewStateMode 


Inherit 
Visible True 


ValidationExpressior \w+([-+.'J\w+)"@\w+ (1. 


ErrorMessage 


ErrorMessage 
当 验 证 的 控件 无 效 时 在 Validationsummary 中 显示 
toe. 


图 4-35 ”控件 属性 设置 


第 7 步 ， 单 击 图 4-37 所 示 的 ValidationExpre- 
ssion 属性 后 的 输入 框 , 进 入 正则 表达 式 编辑 器 , 选 
E“ internet 电子 邮件 地 址 ” ,如 图 4-38 所 示 。 单 击 
“确定 ”按钮 。 

小 提示 : 编写 正则 表达 式 是 有 一 定 难度 的 ,还 
好 常用 的 正则 表示 式 在 网 上 到 处 可 见 ,使 用 时 可 
以 去 网 上 查找 。 

第 8 J ”设置 QQ 的 验证 控件 属性 ,设置 
ControlTovalidate 属性 值 为 tbxQQ, ErrorMessage 属 
性 值 为 "QQ 信息 错误 ”, SetFocusOnError 属性 值 为 


当 验 证 的 控件 无 效 时 在 ValidationSummary 中 显示 


图 4-36 ”控件 属性 设置 


验证 表达 式 (E): 


Nw (E w+)" Nw (1-м) Nw (ми) 


Cw )[ mw ) 


图 4-38 正则 表达 式 设 置 
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True ,如 图 4-39 所 示 。 


ze тех 
CustomValidatorl System.Web.ULWebControl = 


(Expressions) 
(D) CustomValidator1 
AccessKey 

BackColor 

BorderColor 

BorderStyle NotSet 
Border Width 

ClemiDMode Inherit 
ClientValidationFunc 
ControlTovalidate tbxQQ 
CssClass 

Display Static 
EnableClientScript True 
Enabled True 
EnableTheming — True 
EnableViewState Теше 
ErorMessage — QQ 信息 错误 
b Font 

ForeColor 

Height 

SetFocusOnError True 


ToolTip 
ValidateEmptyText False 
ValidationGroup 
ViewStateMode Inherit 
Visible True 
Width 


ErrorMessage 
当 验证 的 控件 无 效 时 在 ValidationSummary 中 显示 
кне. 


Р 4-39 控件 属性 设置 


属性 ”Xx 
CustomValidatorl System.Web.ULWebControl ~ 
"m H- 

DataBinding 

Disposed 

Init 

Load 

PreRender 

ServerValidate CustomValidator1 Serv 

Unload 


图 4-40 控件 事件 设置 


第 9 步 ， 单 击 * 属 性 "窗口 的 “事件 "按钮 ,切换 到 "事件 "窗口 ,如 图 4-40 所 示 。 
第 10 步 ， 单 击 ServerValidate 事件 后 的 输入 框 , 进 入 CustomValidatorl _ServerValidate 方 


法 ,编写 如 下 代码 : 


protected void CustamValidatorl ServerValidate (bject source, 


ServerValidateEventArgs args) 
{ 
bool flag new Fegex (" [1 -9] [0 -9] {5,9}") -Match (оӊ) .Sucoess; 
if (!flag) 
{ 
args.Isvalid-false; 
} 
1 
在 编写 代码 前 ,在 类 的 上 边 加 入 依据 代码 ,代码 如 下 : 
using System. Text .RegularExpressions; 


代码 编辑 完毕 ,效果 如 图 4-41 所 示 。 
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СА Defaultaspxcs x Li] 
H 5 
r RETZ [i8 Page Loadtobject sender, EventArgs е) B 
a using System; + a 
using System.Collections.Generic; Br 
using System.Linq: 3 
using Systen. Web: š 
using System. Web. UI: 1 
using System. yeb.UI.WebControls: E 
using System. Text. RegularExpressions: w 
EL 
public partial class Default? : System. Web. UI. Page a. 
日 protected void Page Load(object sender, Eventrgs 县 
{ й 
П m 
protected void Buttonl Click(object sender, Eventárgs e) š 
B 
1 * 
Sj protected void CustomValidatorl ServerValidste(object source, ServerValidsteEventárgs args) [EE] 
string qq = this. tbxQQ. Text; 
bool flag = new Regex (“ [1-9] [0-9] 15, 91"). Hatch (qq). Success: 
if (flag) 
t 
args. IsValid = false; 
1 
l 
1 
100% Í т. , 


441 自 定义 验证 代码 


第 11 步 ”启动 调试 ,页 面 运行 效果 如 图 4-42 所 示 。 


е8] х 
D localhost2150/chap4-2. х VI 
£ > @ [D localhost2150/chap4-2/Default.aspx = 
用 户 注册 
ВРА. 
密码 : 
确认 密码， 
姓名 ， pu 
өз 
性 别 ， ex 
年 的 ， 
Email, 
С 
学 历 研究 生 v 
目 读 书 
目 音乐 
兴趣 爱好 ӘЖ 
目 旅 游 
目 上 网 


图 4-42 页面 运行 效果 


第 12 步 单 击 “ 注 册 " 按 钮 ,效果 如 图 4-43 所 示 。 

第 13 步 ”在 网 页 上 输入 用 户 名 密码 .姓名 确认 密码 .年龄 .Email QQ 等 信息 后 ,效果 
如 图 4-44 所 示 。 

第 14 步 ” 修 改 不 能 通过 验证 的 数据 后 ( QQ 信息 仍 不 符合 要 求 ) , 单 击 “注册 ”按钮 ,页 
面 效果 如 图 4-45 所 示 。 
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图 4-43 ”验证 效果 


= = 
D localhost2150/chap4-2, x Wl, 
€ > Q [D localhost2150/chap4-2/Default.aspx $E 
WAED: [2 确认 密码 必须 和 密码 相同 
姓名 ， IRS 
© 
L 92 
=, et 年 前 必须 在 18~60 之 间 
Email. — 805325345@qw Email 地 址 不 符合 要 求 ， 请 重新 填写 
99. 123a 
学 历 HER + 
Bike 
BER 
兴趣 爱好 : 目 打 球 
日 旅游 
目 上 网 
[sm] 
+ 确认 窗 码 必须 
ТЕМОЙ ЕЯ минав 


444 ”验证 效果 


elg s= 
Г\ localhost2150/chap4-2, x V. 
€ > Q [D localhost2150/chap4-2/Default.aspx 3s 
用 户 注册 
用 户 名 ， wx 
SS. 1 
ую. 1 
жа. 王 庆 喜 
өя 
性 别 : ox 
年 龄 ， 60 
Email; |805325345@166.com 
Q: 123a QQ 信息 错误 
学 历 HRE т 
mit 
四 音乐 
兴趣 爱好 O3 
aol 
日 上 网 
[sm] 
* QQ 信息 错误 
图 4-45 ”验证 效果 


【任务 小 结 】 

本 任务 使 用 验证 控件 对 用 户 输入 数据 进行 验证 ,涉及 ASP . NET 中 的 验证 控件 。 验 证 
控件 容易 掌握 ,易于 使 用 ,并 且 是 企业 级 应 用 程序 必 不 可 少 .十 分 重要 的 一 个 环节 ,请 注意 掌 
握 好 本 部 分 知识 和 技术 。 

【拓展 提高 】 

1. 正则 表达 式 概念 

正则 表达 式 是 对 字符 串 操作 的 一 种 逻辑 公式 , 即 用 事先 定义 好 的 一 些 特定 字符 、 及 这 些 
特定 字符 的 组 合 , 组 成 一 个 “规则 字符 串 ” ,这 个 “规则 字符 串 " 用 来 表达 对 字符 串 的 一 种 过 

给 定 一 个 正则 表达 式 和 另 一 个 字符 串 ,我 们 可 以 达到 如 下 的 目的 : 

(1) 给 定 的 字符 串 是 否 符合 正则 表达 式 的 过 滤 逻 辑 ( 称 作 * 匹 配 ” ) ; 

(2) 可 以 通过 正则 表达 式 , 从 字符 串 中 获取 我 们 想 要 的 特定 部 分 。 

正则 表达 式 的 特点 如 下 : 

(1) 灵活 性 ,逻辑 性 和 功能 性 非常 强 ，; 

(2) 可 以 迅速 地 用 极 简单 的 方式 达到 字符 串 的 复杂 控制 。 

(3) ЖИЕН ЛЖ, FERME NENE TE 

由 于 正则 表达 式 主要 应 用 对 象 是 文本 ,因此 它 在 各 种 文本 编辑 器 场合 都 有 应 用 ,小 到 著 
名 编辑 器 EditPlus ,大 到 Microsoft Word , Visual Studio 等 大 型 编辑 器 ,都 可 以 使 用 正则 表达 式 
来 处 理 文本 内 容 。 
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2. 正则 表达 式 符 号 
正则 表达 式 的 符号 如 表 4-9 所 示 。 


= # 


表 4-9 正则 表达 式 的 符号 
说 — 明 


将 下 一 字符 标记 为 特殊 字符 ,文本 、 反 向 引用 或 八进制 转 义 符 。 例 如 “n” 匹 配 字符 “n”、 
“\n” 匹 配 换 行 符 、 序 列 “\\” 匹 配 “\”“\(” 匹 配 “(” 


匹配 输入 字符 串 开始 的 位 置 。 如 果 设 置 了 RegExp 对 象 的 Multiline 属性 ,还 会 与 “ Vn" 
或 “\r" 之 后 的 位 置 匹 配 


匹配 输入 字符 串 结 尾 的 位 置 。 如 果 设 置 了 RegExp 对 象 的 Multiline RHE, $ 352: 5" Wn" 
或 “\r" 之 前 的 位 置 匹配 


零 次 或 多 次 匹配 前 面 的 字符 或 子 表达 式 。 例 如 zo * 匹配 *z” 和 “zoo”。* 等 效 于 10,] 


一 次 或 多 次 匹配 前 面 的 字符 或 子 表达 式 。 例 如 “zo +” Ej“ zo" I" zoo" 匹配, 但 与 *z” 不 
匹配 。+ FAF 11,1 


零 次 或 一 次 匹配 前 面 的 字符 或 子 表达 式 。 例 如 “do(es)?" 匹 配 “do” 或 “does” 中 的 
“do”。? 等 效 于 10,11 


п 是 非 负 整 数 。 正 好 匹配 n 次。 例如 “ol21" 与 Bob" 中 的 *o" 不 匹配 ,但 与 “food" 中 的 
两 个 "o" 匹 配 


nn 是非 负 整数 。 至 少 匹配 次。 例如 *o12,1 "不 匹配 “Bob” 中 的 *o” ,而 匹配 “foo000d” 
中 的 所 有 oo “011, ”等 效 于 “o+”。“o{0,1” 等 效 于 “o*” 


M 和 是 非 负 整数 ,其 中 n< =m, MRED n К, 2 mK, 例如“o41,34” 匹 配 
“fooooo0od” 中 的 头 三 个 。。'010,1| 等 效 于 'o7'。 注 意 ,不 能 将 空格 插入 逗号 和 数字 之 间 


当 此 字符 紧 随 任何 其 他 限定 符 ( + 2 inl im, dinum] ) 之 后 时 ,匹配 模式 是 “ 非 贪 
心 的 "。“ 非 贪心 的 "模式 匹配 搜索 到 的 、 尽 可 能 短 的 字符 串 ,而 默认 的 “贪心 的 "模式 匹 
配 搜索 到 的 、 尽 可 能 长 的 字符 串 。 例 如 在 字符 串 *oo0oo0" 中 ,“o+?” 只 匹配 单个 “o” ,而 
“o+” IREA “o” 


匹配 除 “\n" 之 外 的 任何 单个 字符 。 若 要 匹配 包括 “\n" 在 内 的 任意 字符 ,请 使 用 诸如 
“[\s\S] "之 类 的 模式 


(pattern) 


匹配 pattern 并 捕获 该 匹配 的 子 表达 式 。 可 以 使 用 $0… $9 属性 从 结果 “匹配 "集合 中 
检索 捕获 的 匹配 。 若 要 匹配 括号 字符 ( ) ,请 使 用 *\( "或 者 *\)” 


(?:pattern) 


匹配 pattern 但 不 捕获 该 匹配 的 子 表达 式 , 即 它 是 一 个 非 捕获 匹配 ,不 存储 供 以 后 使 用 的 
匹配 。 这 对 于 用 “or” 字 符 (1) 组 合 模式 部 件 的 情况 很 有 用 。 例 如 'industr(?:ylies) 是 
HE industrylindustries' 更 经 济 的 表达 式 


(? = pattern ) 


执行 正 向 预测 先行 搜索 的 子 表 达 式 ,该 表达 式 匹 配 处 于 匹配 pattern. 的 字符 串 的 起 始点 
的 字符 串 。 它 是 一 个 非 捕获 匹配 , 即 不 能 捕获 供 以 后 使 用 的 匹配 。 例 如 'Windows (? =95 
198 I NT | 2000 ) "Е йо“ Windows 2000" 中 的 “ Windows”, 但 不 匹配 “Windows 3. 1" 中 的 
“Windows”。 预 测 先行 不 占用 字符 , 即 发 生 匹 配 后 ,下 一 匹配 的 搜索 紧 随 上 一 匹配 之 后 ， 
而 不 是 在 组 成 预测 先行 的 字符 后 


( ?1pattern) 


执行 反 向 预测 先行 搜索 的 子 表达 式 ,该 表达 式 匹配 不 处 于 匹配 pattern. 的 字符 串 的 起 始 
点 的 搜索 字符 串 。 它 是 一 个 非 捕获 匹配 , 即 不 能 捕获 供 以 后 使 用 的 匹配 。 例 如 Windows 
(2?!951981NTI2000) 匹 配 * Windows 3.1” 中 的 “Windows” ,但 不 匹配 “Windows 2000” rH 
的 “Windows”。 预 测 先 行 不 占用 字符 , 即 发 生 匹 配 后 ,下 一 匹配 的 搜索 紧 随 上 一 匹配 之 
后 ,而 不 是 在 组 成 预测 先行 的 字符 后 


xly 
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匹配 x 或 y。 例 如 zlfood 匹 配 *z" 或 “food” (zlf)ood 匹 配 *“zood” 或 “food” 


= # 说 H 

[xyz] 字符 集 。 匹 配 包含 的 任 一 字符 ,例如 * [ abe ] IR“ plain” HHY“ a” 

[^92] 反 向 字符 集 。 匹 配 未 包含 的 任何 字符 。 例 如 *[ abc] " йс“ plain" PHY“ p" 

faa] 字符 范围 。 匹 配 指定 范围 内 的 任何 字符 。 例 如 *[a -z] "匹配 *“a" 到 “z" 范 围 内 的 任何 

7 小 写字 母 

Pacal 反 向 范围 字符 。 匹 配 不 在 指定 的 范围 内 的 任何 字符 。 例 如 *[ ^а -z]” 匹 配 任何 不 在 “a” 
到 “z” 范 围 内 的 任何 字符 

M 匹配 一 个 字 边 界 , 即 字 与 空格 间 的 位 置 。 例 如 “er\b” 匹 配 *“never” 中 的 “er”, 但 不 匹配 

j “verb” HHJ“ er” 

\B 非 字 边界 匹配 。“er\B” 匹配 “verb” 中 的 “er” ,但 不 匹配 “never" 中 的 “er” 

" 匹配 x 指示 的 控制 字符 。 例 如 \eM 匹配 Control - M 或 回 车 符 。x 的 值 必须 在 A ~Z 或 a 

~z 之 间 。 如 果 不 是 这 样 , 则 假定 c 就 是 “ec" 字 符 本 身 

\d 数字 字符 匹配 。 等 效 于 [0 -9] 

\D 非 数 字 字 符 匹配 。 等 效 于 [ O -9] 

M 换 页 符 匹配 。 等 效 于 \x0c 和 \eL 

\n 换行 符 匹配 。 等 效 于 \x0a 和 \cJ 

\г 匹配 一 个 回 车 符 。 等 效 于 \x0d 和 \eM 

\s 匹配 任何 空白 字符 ,包括 空格 , 制 表 符 . 换 页 符 等 。 与 [ \f\n\r\t\v] 等 效 

\S 匹配 任何 非 空 白字 符 。 与 [“\f\n\r\t\v] 等 效 

M 制 表 符 匹 配 。 与 \x09 和 \cl 等 效 

Ww 垂直 制 表 符 匹配 。 与 \x0b 和 \eK 等 效 

uw 匹配 任何 字 类 字符 ,包括 下 划 线 。 与 “[A -Za -z0 -9_] ”等 效 

Ww 与 任何 非 单词 字符 匹配 。 与 “[“A -Za -z0 -9_] "等 效 

\ 匹配 ,此 处 的 n 是 一 个 十 六 进 制 转 义 码 。 十 六 进 制 转 义 码 必 须 正好 是 两 位 数 长 。 例 如 

ш “Wx41” 匹 配 “A”。*“\x041” 与 “\x04”&*1” 等 效 。 允 许 在 正则 表达 式 中 使 用 ASCII 代码 

" 匹配 num, 此 处 的 пит 是 一 个 正 整数 。 到 捕获 匹配 的 反 向 引用 。 例 如 *(.)\1" 匹 配 两 

ii 个 连续 的 相同 字符 

标识 一 个 八进制 转 义 码 或 反 向 引用 。 如 果 \n 前 面 至 少 有 nn 个 捕获 子 表达 式 , 那 么 n 是 
反 向 引用 。 否 则 ,如 果 n 是 八进制 数 (0 ~7) ,那么 是 八进制 转 义 码 
标识 一 个 八进制 转 义 码 或 反 向 引用 。 如 果 \nm 前 面 至 少 有 nm 个 捕获 子 表达 式 , 那 么 

\ nm 是 反 向 引用 。 如 果 \nm 前 面 至 少 有 nn 个 捕获 , 则 nn 是 反 向 引用 ,后 面 跟 有 字符 m. АД 

m 果 两 种 前 面 的 情况 都 不 存在 , 则 \nm 匹配 八进制 值 mm, 其 中 和 m 是 八进制 数字 (0 ~ 
7) 

\nml M п 是 八进制 数 (0 ~3) „т 和 1 是 八进制 数 (0 ~7) 时 ,匹配 八进制 转 义 码 nml 

Xun DERE n, Fei 是 以 四 位 十 六 进 制 数 表 示 的 Unicode 字符 。 例 如 \u00A9 匹配 版 权 符 号 (@) 


3. .NET 正则 核心 对 象 
(1) Regex 类 。 该 类 是 . NET 正则 表达 式 的 核心 。 其 中 包括 了 若干 静态 方法 ,这 使 得 可 
以 不 构造 Regex 对 象 就 可 以 使 用 其 功能 。 Regex 类 是 不 可 变 ( 只 读 ) 的 ,并 且 具 有 固有 的 线 
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程 安全 性 。 可 以 在 任何 线程 上 创建 Regex 对 象 ,并 在 线程 间 共 享 。 一 般 可 以 利用 该 类 的 构 
造 函 数 来 定义 所 需要 的 表达 式 及 匹配 模式 。 
(2) Match 类 。 该 类 用 于 表示 单个 正则 表达 式 的 匹配 。 可 以 通过 多 种 方式 来 得 到 该 对 象 ; 
CD 利用 Regex. Match( ) 方 法 返回 一 个 Match 对 象 ; 
@ 利用 Match 对 象 本 身 的 NextMatch( ) 方 法 来 返回 一 个 新 的 Match 对 象 。 
正则 表达 式 用 于 字符 串 处 理 .表单 验证 等 场合 ,实用 高 效 。 现 将 一 些 常用 的 表达 式 收 集 
于 此 ,以 备 不 时 之 需 。 
4. 常用 正则 表达 式 
匹配 HTML 标记 的 正则 表达 式 : <(\S*?)[^>]*>.*?</\1>1<.*?/>。 
匹配 E-mail 地 址 的 正则 表达 式 : Nw ([ 一 +.]\Ww+)*@\w+([-.]\Ww+)*\.\w 
+([-.]\w+)*o。 
匹配 网 址 URL 的 正则 表达 式 : [а - 2А —z] +://[^\з] *。 
匹配 国内 电话 号 码 : \dj3| - \dl811\di41 -\4{7} 
匹配 腾讯 QQ 号 : [1 -91[0-9]14, |. 
匹配 中 国 邮政 编码 : [1 -9]\d|51(?1\d)。 
匹配 身份 证 : Vd|1511Ad1181. 
匹配 IP 地 址 : \d + \. ла + \. ла + \. ла +, 


任务 4-3 ”使 用 导航 控件 制作 菜单 


【任务 描述 】 

小 王 开 发 了 一 个 应 用 ,在 这 个 应 用 中 有 很 多 功能 ,但 是 这 些 功能 分 散在 很 多 网 页 中 ,他 想 
把 这 些 功能 网 页 组 织 起 来 ,可 以 快速 地 访问 ,而 不 是 做 什么 操作 临时 去 找 对 应 的 网 页 ,这 时 他 
想到 了 ASP . NET 中 的 导航 控件 ,现在 他 要 使 用 这 些 控件 制作 他 开发 应 用 中 的 菜单 。 

【任务 目的 】 

(1) 掌握 TreeView , Menu 控件 的 主要 使 用 。 

(2) 掌握 SiteMapDataSource 的 使 用 ,以 及 结合 TreeView Menu 控件 快速 制作 系统 菜单 。 

【任务 分 析 】 

任务 是 制作 菜单 ,这 在 ASP . NET 中 不 是 难事 ,因为 ASP . NET 提供 了 导航 科技 ,只 要 使 
用 这 些 控 件 , 在 几 分 钟 内 就 能 制作 出 令 人 满意 的 菜单 。 

【基础 知识 】 

1. 导航 控件 

对 于 一 个 网 站 来 说 ,如 果 没 有 导航 ,用 户 在 使 用 总 就 会 很 困难 ,因此 除非 你 的 应 用 十 分 
小 ,只 有 一 两 个 功能 ,否则 就 必须 提供 导航 。 在 ASP . NET 中 导航 控件 有 TreeView .Menu 和 
SiteMapPath 。 

小 提示 : 几乎 没有 应 用 程序 不 使 用 导航 ,但 是 一 个 系统 通常 只 有 一 个 导航 。 

2. 站 点 地 图 文件 

站 点 地 图 文件 是 一 个 名 为 Web. sitemap 的 XML 文件 ,这 个 文件 必须 位 于 应 用 程序 的 根 
目录 下 ,并且 不 能 更 改 它 的 名 字 。 这 个 文件 会 被 ASP . NET 直接 读 取 , 直接 把 值 给 
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SiteMapDataSource 控件 。 

3. SiteMapDataSource 控件 

SiteMapDataSource 控件 是 一 个 数据 源 控件 ,位 于 工具 箱 中 的 “数据 ”控件 中 ,这 个 控件 
只 需 拖 放 到 页 面 ,就 可 以 直接 使 用 , 它 直接 读 取 Web. sitemap 这 个 XML 文件 。 

4. TreeView 控件 

TreeView 控件 是 一 个 十 分 普及 的 控件 ,每 个 电脑 使 用 者 基本 每 天 都 要 使 用 到 它 。 
TreeView 控件 大 大 简化 了 开发 人 员 编 写 导航 功能 的 复杂 性 , 它 用 于 树 结 构 中 显示 分 层 数据 ， 
例如 目录 或 文件 目录 。 

TreeView 使 用 方便 ,提供 如 下 功能 : 

(1) 数据 绑 定 ,人 允许 控件 的 结 点 绑 定 到 XML 表格 和 关系 数据 。 

(2) 站 点 导航 ,通过 与 SiteMapDataSource 控件 集成 实现 

(3) 结 点 文本 既 可 以 显示 为 村 文本 也 可 以 显示 为 超 链 接 。 

(4) 借助 编程 方式 访问 TreeView 对 象 模型 以 动态 创建 树 .填充 结 点 .设置 属性 等 。 

(5) 客户 端 结 点 填充 。 

(6) 在 每 个 结 点 旁 显示 复 选 框 的 功能 。 

(7) 通过 主题 ,用户 定义 的 图 像 和 样式 可 实现 自 定 义 外 观 。 

5. Menu 控件 

Menu 控件 可 以 在 网 页 上 模拟 Windows 的 菜单 导航 效果 , 它 可 以 呈现 两 种 模式 。 

(1) 静态 模式 : Menu 控件 的 菜单 完全 展开 ,用 户 可 以 单 击 菜单 中 的 任何 项 。 

(2) 动态 模式 : 默认 值 显 示 部 分 内 容 , 当 用 户 移动 鼠标 到 静态 内 容 项 上 时 , 则 淡出 子 菜 
单项 。 

静态 显示 模式 下 ,Menu 控件 的 StaticDisplayLevels 属性 控制 静态 显示 行为 ,指定 包含 跟 
菜单 在 内 的 静态 显示 菜单 的 层 数 ,StaticDisplayLevels 的 最 小 值 为 1。 

动态 显示 模式 下 ,Menu 的 MaximumDynamicDisplayLevels 属性 指定 静态 显示 层 后 应 显 
示 的 动态 显示 菜单 的 结 点 数 , MaximumDynamicDisplayLevels 最 小 值 为 0, 表示 动态 显示 不 会 
有 任何 结 点 。 

【任务 实施 】 

ЖЯ 1% 新建 空 网 站 chap4-3 ,添加 新 项 Web 窗 体 ,采用 默认 值 Default. aspx。 

第 2 步 向 网 站 添加 新 项 “站 点 地 图 ” ,名 称 采用 默认 值 , 此 处 不 用 修改 ,如 图 4-46 所 示 。 

第 3 步 ” 在 站 点 地 图 文件 中 输入 如 下 代码 : 


<? xml version ="1.0" encoding -"utf -8" ? > 
«siteMep xmlns —"http: //schemas.microsoft .oa/AscNet/SiteMap -File -1.0" > 
«siteMsrNode url =" title =P " description =" > 
<siteMepNode url ="cxmputer.aspx" title="}t # 机" description =" > 
<siteMapNcde url=" title =" К," description="" /> 
<sitsMekNode url=" title 二 笔记 本 " description 2" /> 
«/siteMapNode > 
<sitevepNode url =" title "B" description =" > 
<siteMepNode url =" Ше =" Й" description =" /> 
<siteMapNode url =" title 一 计算 机 类 " description =" > 
«siteMspNode url ="ASP .NET.aspx" title -"ASP .NET" description =" /> 
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图 4-46 添加 站 点 地 图 


«siteMsriNode url=" title ="ASP" description =" /> 
«/siteMapNode > 
<= емо ш =" title =" 2" description =" /> 
«/siteMapNode > 
«/siteMapNode > 
</siteMap > 


第 4 步 ” 向 网 页 中 拖 放 一 个 TreeView 控件 和 一 个 SiteMapDataSource 控件 ,注意 ,这 两 


个 控件 位 置 不 同 ,TreeView 控件 在 工具 箱 中 的 “导航 "中 ,SiteMapDataSource 控件 在 工具 箱 中 
的 “数据 "中 ,如 图 4-47 所 示 。 


图 447 TreeView 控件 


第 5 步 WE TreeView 控件 ,选择 数据 源 SiteMapDataSourcel , TreeView 的 结 点 会 自动 
更 新 ,如 图 4-48 所 示 。 

第 6 步 ”启动 调试 ,页 面 运行 效果 如 图 4-49 所 示 。 

72 Pil ASP .NET" 超 链接 ,页 面 发 生 跳 转 ,因为 超 链接 指向 的 网 页 不 存在 ,所 以 
出 现 “ 无 法 找到 资源 "错误 ,如 图 4-50 所 示 。 
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图 4-48 选择 数据 源 


图 4-49 页 面 运行 效果 


€ > C |D localhost:2860/chap4-3/asp.net.aspx 


/chap4-3" 应 用 程序 中 的 服务 器 错误 。 


SEE. 


说 明 : НТТР 404» 您 正在 查找 的 资源 或 者 它 的 一 个 依 琐 硕 问 能 已 被 移 除 ， 或 其 名 称 已 更 改 ， 或 暂时 不 可 用 。 请 检查 以 下 
URL 并 确保 其 拼写 正确 * 


请 求 的 URL: /chap4-3/asp.netaspx 


版 本 信息 : Microsoft NET Framework 版 本 :4.0.30319; ASP.NET 版 本 :4.0.30319.1022 


图 4-50” 超 链接 
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【任务 小 结 】 

本 任务 介绍 了 使 用 TreeView , Menu 导航 控件 和 SiteDataSource 数据 源 控件 制作 网 站 菜 
单 的 知识 以 及 开发 过 程 。 使 用 ASP . NET 提供 的 导航 控件 可 以 快速 地 实现 菜单 功能 ,并 且 
实现 效果 也 相当 令 人 满意 。 

【拓展 提高 】 

使 用 Menu 制作 菜单 : 

第 1 步 在 网 站 chap4-3 中 ,添加 新 项 Default2. aspx, 向 添加 的 网 页 上 拖 电 一 个 Menu 
控件 ,为 Menu 编辑 菜单 项 ,如 图 4-51 所 示 。 编 辑 好 后 , 单 击 “确定 "按钮 。 


Led 


图 4-51 编辑 Menu 菜单 项 
第 2 步 ”启动 调试 ,网 页 运行 效果 如 图 4-52 所 示 。 


4-2 ”页 面 运行 效果 


任务 4-4 使 用 母 版 


【任务 描述 】 
小 王 在 开发 一 个 应 用 过 程 中 ,发 现 了 一 个 令 他 苦恼 的 事情 ,网 站 中 很 多 网 页 中 出 现 一 部 分 
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内 容 相同 ,他 每 次 都 要 把 这 些 内 容 从 一 个 页 面 复 制 到 另 一 个 页 面 ,但 是 在 这 些 相同 的 内 容 需要 
修改 时 ,他 需要 把 几乎 所 有 的 网 页 都 修改 一 篇 。 偶 然 的 机 会 , 听 说 母 版 也 可 以 扫除 他 的 烦恼 。 


【任务 目的 】 
(1) 理解 母 版 页 的 概念 。 
(2) 掌握 母 版 页 的 创建 和 使 用 。 


【任务 分 析 】 

母 版 页 可 以 理解 成 网 页 的 母亲 ,其 他 的 网 页 可 以 从 母 版 页 创建 ,并 且 一 创建 就 拥有 了 母 版 
页 的 内 容 , 也 就 是 说 来 自 于 同一 个 母 版 页 的 网 页 具有 相同 的 内 容 , 当 这 些 公用 的 内 容 需要 修改 
时 ,只 需要 修改 母 版 页 即 可 。 因 此 本 任务 需要 先 创建 母 版 页 ,然后 从 母 版 页 创建 新 网 页 。 


【基础 知识 】 

母 版 页 类 似 于 模板 ,允许 在 多 个 页 面 中 共享 相同 的 内 容 。 一 个 从 母 版 页 创建 的 网 页 由 
两 部 分 组 成 ,一 部 分 是 母 版 页 内 容 , 一 部 分 是 本 身 的 内 容 。 母 版 页 的 扩展 名 为 . master, 创建 
后 , 母 版 页 内 至 少 会 有 一 个 区 域 : 这 个 区 域 是 在 网 页 创建 后 可 编辑 的 区 域 ,区 域 是 由 如 下 代 
码 形成 的 ,这 段 代 码 , 或 者 说 这 个 区 域 不 能 从 母 版 页 中 删除 。 

<asp:ContentPlaosHolder id ="СопбепЕР1асеНо1дег1" runat -"server" > 

</asp:ContentPlaceHplder > 

使 用 母 版 页 可 以 简化 维护 .扩展 和 修改 网 站 的 过 程 ,并 能 提供 一 致 统一 的 的 外 观 。 

小 提示 : 网 页 框架 技术 由 于 其 缺点 ,使 用 的 人 越 来 越 少 ,取而代之 的 主要 就 是 母 版 技 
术 , 这 也 是 微软 公司 推荐 使 用 的 网 页 技术 。 


【任务 实施 】 
第 1 步 新 建 空 网 站 chap4-4 ,添加 新 项 母 版 页 ,如 图 4-53 所 示 。 
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图 4-53 ”添加 母 版 页 
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第 2 步 向 网 页 中 的 红色 边框 的 区 域 的 上 下 个 拖 放 一 个 Panel ,并 在 Panel 中 ,录入 
“ASP .NET 学 习 网 站 ”和 “ASP .NET 学 习 兴 趣 小 组 ”, 如 图 4-54 所 示 。 


Р 4-54 ” 母 版 页 内 容 


小 提示 : 母 版 页 至 少 有 一 个 ContentPlaceHolder 控件 ,当然 可 以 根据 需要 放置 多 个 。 
第 3 步 ”添加 新 项 Web 窗 体 ,选中 “选择 母 版 页 "前 的 选择 框 ,名 称 采 用 默认 值 ,如 
图 4-55 所 示 。 


Visual Basic 
Visual C 


35у Dynamic Data $ 
HTML 页 Visual C# 
JScript xt Visual ce 


B LINQ to SQL&& Visual cx 


区 Silverlight 1.0 JScript 页 Visual C 


图 4-55 从 母 版 页 添加 Web Ж 
第 4 步 ， 单 击 “ 确 定 "按钮 ,打开 * 选 择 母 版 页 "窗口 ,如 图 4-56 所 示 。 


图 4-56 ”选择 母 版 页 
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第 5 步 ” 选 中 母 版 页 , 单 击 “确定 "按钮 ,创建 新 Web 窗 体 成 功 ,并 把 母 版 页 内 容 带 到 网 
页 ,如 图 4-57 所 示 。 


图 4-57 母 版 页 制作 的 Web 窗 体 
第 6 步 ” 在 红色 边框 中 输入 内 容 , 如 图 4-58 所 示 。 


Em 上 5 ЕЕ 
а BERE, AP : 的 
PROB А Е СЕРКЕ АЙИН, DETUR IS 
内 几 大 类 。 
1、HTML 服 务 器 控件 ， 简 单 封装 HTML 元 素 形成 的 。 


2、web 服 务 器 控件 : 这 些 控件 不 但 具有 HTML 的 功能 ， 而 且 提供 了 更 多 有 用 的 属性 和 方法 ， 是 开发 人 员 更 容易 定义 | 
和 和 访问, 这 一 部 门 是 本 项 目的 重点 。 
3、 验 证 控件 : 对 数据 进行 


а 数据 控件 : 显示 大 量 站 据 的 控件 ， 本 项 目 不 涉 及 ,会 在 后 半 项 目 中 学 习 。 
з, ея: ARDET MRBS. 


6. ASP.NET JAX 控 件 : 在 : ME га гла 本 项 目 不 涉 及 ， 会 在 后 续 项 目 中 学 习 。] 


图 4-58 ”编辑 自 定义 内 容 
第 7 步 ” 启动 调试 ,页 面 运行 效果 如 图 4-59 所 示 。 
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图 4-59 ”页面 运行 效果 


【任务 小 结 】 


本 任务 介绍 了 网 站 开发 中 母 版 页 的 应 用 ,关键 是 母 版 页 
使 用 ,任务 本 身 不 难 ,难点 在 于 根据 网 页 建设 需求 设计 出 


Vy, 项目 小 结 


的 创建 和 网 页 创建 时 母 版 页 的 
合理 的 母 版 页 。 


本 项 目 主要 学 习 服 务 器 控件 ,这 是 ASP . NET 所 特有 的 , 相 比 于 其 他 应 用 编程 技术 在 网 
页 部 分 具有 巨大 优势 ,也 是 ASP . NET 技术 入 门 简 单 的 原因 之 一 。 服 务 器 控件 是 ASP 
. NET 的 精髓 ,也 是 网 站 应 用 使 用 最 广泛 的 技术 。 本 项 目 采 用 4 个 任务 ,对 主要 的 服务 器 控 


+ M» 


件 进 行 了 介绍 ,还 有 一 类 服务 器 控件 基本 没有 涉及 , 那 就 是 数据 控件 ,在 后 续 项 目 中 会 详细 
介绍 。 


五 、 项 目 考核 


1. 填空 题 
(1) 在 Web 服务 器 控件 中 , AutoPostBack 属性 的 功能 是 в 
(2) 控件 用 来 在 Web 页 面 上 创建 一 个 按钮 。 
(3) 验证 控件 的 Display 属性 可 以 取 值 为 
2. 选择 题 
(1) 在 Button 控件 中 ,用 于 停止 验证 控件 的 属性 是 ( js 
A. Validation 属性 B. Causes 属性 
C. CasesValidation 属性 D. ControlToValidation 属性 
(2) 使 用 ValidatorSummary 控件 时 需要 以 对 话 框 的 形式 来 显示 错误 信息 ,需要 ( )。 
A. 设置 ShowSummary X true В. 设置 ShowMessgeBox X true 
C. 设置 ShowSummary X false D. 设置 ShowMesseageBox 为 false 
(3) 在 以 下 验证 控件 中 ,不 需要 指定 ControlToValidation 属性 的 验证 控件 是 ( Jo 


A. CompareValidator 控件 B. RangeValidator 控件 
C. CustomValidator 控件 D. ValidationSummary 控件 


(4) 在 验证 控件 中 ,ErrorMessage 属性 和 Text 属性 均 设 置 有 文本 信息 , 当 验 证 失败 时 ， 
验证 控件 显示 的 错误 信息 提示 ( ) 中 设置 的 文本 信息 。 


A. ErrorMessagte 属性 B. Text 属性 
C. 不 显示 D. 不 能 确定 
3. 简 答 题 


(1) 简 述 TextBox 控件 的 TextMode 属性 。 

(2) 简 述 标准 控件 中 的 AutoPostBack 属性 。 

(3) DropDownList 控件 的 选项 如 何 设置 ? 

(4) 验证 控件 中 有 哪些 共同 的 属性 ? 

4. 上 机 操作 题 

(1) 设计 一 个 登录 页 面 ,网 页 上 有 用 户 名 密码 ,用户 角 色 3 个 录入 ,用 户 角色 使 用 下 拉 
框 或 单 选 框 实现 。 

(2) 制作 一 个 界面 ,有 多 个 输入 ,并 使 用 验证 控件 对 其 进行 验证 。 
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项 目 5 数据库 与 ADO. NET 
= ala 


数据 是 应 用 程序 的 “灵魂 ”, 没 有 数据 ,程序 毫 无 用 处 ,对 于 信息 管理 系统 应 用 更 是 如 
此 。 在 程序 中 数据 如 何 管理 是 程序 开发 的 核心 。 数 据 的 保存 经 历 了 几 个 阶段 ,起初 ,数据 是 
不 保存 的 ,后 来 数据 都 是 保存 在 文件 中 的 ,但 是 文件 保存 数据 效率 低 .共享 性 低 ,无 法 满足 用 
户 的 需求 ,因此 逐渐 被 数据 库 代 替 。 通 过 数据 库 管理 ,可 以 方便 地 对 程序 的 数据 进行 读 取 、 
插入 修改 和 删除 等 操作 。 


二 、 项 目 要 点 


本 项 目 通过 两 个 任务 讲解 了 SQL Server Management Studio( SSMS ) 操作 SQL Server 数据 
库 ,在 应 用 程序 开发 中 常用 的 SQL 语句 ,ADO. NET 的 核心 类 以 及 连接 数据 库 的 步骤。SQL 
Server 的 相关 内 容 是 为 没有 系统 学 习 过 数据 库 知 识 的 读者 准备 的 ,对 于 熟悉 SQL Server Ж 
据 库 的 读者 可 以 跳 过 任务 5-1。 

要 求 掌 握 数 据 库 SQL Server 2008 的 安装 .配置 和 基本 使 用 ;掌握 在 Visual Studio 2010 


中 连接 SQL Server 2008 数据 库 ; 掌 握 ADO. NET 的 核心 类 的 主要 属性 和 方法 ;掌握 ADO 
. NET 的 连接 数据 的 过 程 步骤 。 
三 、 任 务 
任务 5-1 使 用 数据 库 管 理学 生 信息 
【任务 描述 】 


小 王 开发 应 用 程序 时 ,客户 要 求 数据 必须 保存 到 SQL Server 数据 库 中 ,这 可 是 对 小 王 提 
出 了 不 小 的 挑战 ,因为 他 以 前 没有 使 用 过 SQL Server 数据 库 , 他 要 在 很 短 的 时 间 内 学 会 并 能 
使 用 数据 库 进行 程序 开发 。 

【任务 目的 】 

(1) 掌握 数据 库 的 相关 概念 。 

(2) 掌握 程序 开发 时 常用 的 SQL 语句 。 

(3) 掌握 SSMS 数据 库 客 户 端的 使 用 。 

【任务 分 析 】 

对 于 程序 开发 而 言 ,数据 库 的 知识 主要 是 SQL 语言 和 数据 库 的 基本 操作 。 在 开发 中 
ЖЯ Л.Ж SQL 语句 使 用 频率 是 非常 高 的 ,这 些 必 须 掌 握 ; 数 据 库 的 操作 基本 上 都 是 使 用 工 
具 , 使 用 工具 可 以 简化 操作 ,使 数据 库 使 用 起 来 更 方便 ,微软 公司 为 SQL Serer 制作 了 
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SSMS 客户 端 (SQL Server Management Studio) ,可 以 通过 可 视 化 界面 的 形式 管理 和 操作 数 
据 库 。 

【基础 知识 】 

1. 数据 库 

数据 库 指 的 是 以 一 定 方式 储存 在 一 起 .能 为 多 个 用 户 共 享 . 具有 尽 可 能 小 的 元 余 度 .与 
应 用 程序 彼此 独立 的 数据 集合 ,数据 库 具 有 如 下 优势 。 

(1) 实现 数据 共享 。 

(2) 少数 据 的 元 余 度 。 

(3) 数据 的 独立 性 。 

(4) 数据 实现 集中 控制 。 

(5) 数据 一 致 性 和 可 维护 性 ,以 确保 数据 的 安全 性 和 可 靠 性 。 

(6) 故障 恢复 。 

目前 主流 的 数据 库 是 关系 型 数据 库 , 除 此 而 外 还 有 一 些 其 他 类 型 的 数据 库 也 越 来 越 受 
到 重视 ,比如 面向 对 象 数据 库 XML 数据 库 .多 媒体 数据 库 .空间 数据 库 等 。 

管理 数据 库 的 软件 称 作 数据 库 管 理 系 统 , 是 一 个 系统 软件 ,目前 主流 的 数据 库 管 理 系统 
有 SQL Server .Oracle .DB2 , MySQL 等 。SQL Server 数据 库 和 . NET 技术 都 属于 微软 公司 , 因 
此 它们 之 间 的 集成 开发 具有 绝对 优势 ,使 用 ASP . NET 技术 的 开发 者 绝 大 多 数 都 会 采用 
SQL Server 数据 库 , 因 此 本 书 示例 数据 库 也 采用 微软 的 SQL Server 数据 库 。 

2. SQL Server 数据 库 

SQL Server 是 一 个 关系 数据 库 管理 系统 。 它 最 初 是 由 Microsoft Sybase 和 Ashton-Tate 3 
家 公司 共同 开发 的 ,于 1988 年 推出 了 第 一 个 OS/2 版 本 。 在 Windows NT 推出 后 , Microsoft 
与 Sybase 在 SQL Server 的 开发 上 就 分 道 扬 镰 了 ,Microsoft 将 SQL Server 移植 到 Windows NT 
系统 上 ,专注 于 开发 推广 SQL Server 的 Windows NT 版 本 。 

Microsoft SQL Server 2008 是 一 个 重大 的 产品 版 本 , 它 推出 了 许多 新 的 特性 和 关键 的 改 
进 , 使 得 它 成 为 至 今 为 止 最 强大 和 最 全 面 的 Microsoft SQL Server 版 本 。 微 软 的 这 个 数据 平 
台 满 足 这 些 数据 爆炸 和 下 一 代数 据 驱动 应 用 程序 的 需求 ,支持 数据 平台 愿景 : 关键 任务 企 
业 数据 平台 动态 开发 .关系 数据 和 商业 智能 。 这 个 平台 有 以 下 特点 。 

(1) 可 信任 。 使 得 公司 可 以 以 很 高 的 安全 性 、 可 靠 性 和 可 扩展 性 来 运行 他 们 最 关键 任 
务 的 应 用 程序 。 

(2) 高 效 。 使 得 公司 可 以 降低 开发 和 管理 他 们 的 数据 基础 设施 的 时 间 和 成 本 。 

(3) 智能 。 提 供 了 一 个 全 面 的 平台 ,可 以 在 用 户 需 要 时 发 送 观 察 和 信息 。 

知识 链接 : SQL Server 主要 通过 SSMS 进行 管理 ,包括 创建 数据 库 、 表 、 视 图 、 索 引 等 , 册 
除数 据 库 . 表 、 视 图、 索引 等 ,备份 恢复 数据 库 , 分 离 附加 数据 库 等 。 

3. SSMS 

SSMS( Microsoft SQL Server Management Studio) 是 Microsoft SQL Serve 提供 的 一 种 新 集 
成 环境 ,用 于 访问 .配置 控制 ,管理 和 开发 SQL Server 的 所 有 组 件 。SQL Server Management 
Studio 将 一 组 多 样 化 的 图 形 工具 与 多 种 功能 齐全 的 脚本 编辑 器 组 合 在 一 起 ,可 为 各 种 技术 
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级 别 的 开发 人 员 和 管理 员 提 供 对 SQL Server 的 访问 。 

小 提示 : SSMS 是 一 个 操作 数据 库 的 工具 ,这 个 工具 可 以 帮助 我 们 方便 地 访问 和 管理 数 
据 库 ,因此 需要 很 好 地 掌握 。 

4. SQL 语言 

结构 化 查询 语言 (Structured Query Language,SQL) 是 一 种 数据 库 查 询 和 程序 设计 语言 ， 
用 于 存 取 数 据 以 及 查询 更 新 和 管理 关系 数据 库 系 统 ;同时 也 是 数据 库 脚本 文件 的 扩展 名 。 
结构 化 查询 语言 是 高 级 的 非 过 程 化 编程 语言 ,允许 用 户 在 高 层 数 据 结 构 上 工作 。 它 不 要 求 
用 户 指定 对 数据 的 存放 方法 ,也 不 需要 用 户 了 解 具体 的 数据 存放 方式 ,所 以 具有 完全 不 同 底 
层 结构 的 不 同 数据 库 系统 , 可 以 使 用 相同 的 结构 化 查询 语言 作为 数据 输入 与 管理 的 接口 。 
结构 化 查询 语言 语句 可 以 艇 套 ,这 使 它 具 有 极 大 的 灵活 性 和 强大 的 功能 。 

SQL 于 1974 年 由 Boyce 和 Chamberlin 提出 ,并 在 IBM 公司 研制 的 关系 型 数据 库 管理 系 
统 原型 System R 上 实现 ,SQL 标准 从 1986 年 公布 以 来 随 着 数据 库 技 术 的 发 展 而 不 断 发 展 不 
断 丰 富 ,SQL 语言 具有 如 下 特点 。 

(1) 综合 统一 : SQL 集 数据 定义 DDL .数据 操纵 DML 和 数据 控制 DCL 于 一 体 , 语 言 风 
格 统一 ,可 以 完成 数据 库 中 的 全 部 工作 。 

(2) 使 用 方式 灵活 : 它 具 有 两 种 使 用 方式 , 既 可 以 直接 以 命令 方式 交互 使 用 ;也 可 以 髓 
和 人 使 用 ,嵌入 到 CC ++ FORTRAN .COBOL Java 等 主语 言 中 使 用 。 

(3) 非 过 程 化 : 只 提 操 作 要 求 ,不 必 描 述 操作 步骤 ,也 不 需要 导航 。 使 用 时 只 需要 告诉 
计算 机 “做 什么 ” ,而 不 需要 告诉 它 “ 怎 么 做 ”。 

(4) 语言 简洁 ,语法 简单 ,好 学 好 用 : 在 ANSI 标准 中 ,只 包含 了 94 个 英文 单词 ,核心 功 
能 只 用 6 个 动词 ,语法 接近 英语 口语 。 

(5) 面向 集合 的 操作 方式 : 不 仅 操作 对 象 .查找 结果 可 以 是 元 组 的 集合 ,而 且 一 次 揪 
入 删除 ,更 新 操作 的 对 象 也 可 以 是 元 组 的 集合 。 

查询 语法 : 

SELECT < 目标 列 名 序列 > 

FROM. < 数据 源 > 

[WHERE < 条 件 表达 式 >] 

[GROUP BY < 分 组 依据 >] 

EVN < 组 提取 条 件 >] 

[CREER BY < 排序 依据 列 >desc lasc] 


插入 语法 : 

NER NO KE (FRIR) МАШЕ5 ØK) 

修改 语法 : 

UPDATE, KEE < 列 名 KA >[…] [WHERE < 修改 条 件 习 
删除 语法 

IELETE FROM < 表 名 [WHERE < 删除 条 件 >] 


知识 链接 : 在 SQL 语句 中 ,查询 语句 比较 复杂 ,尤其 是 逻辑 复杂 的 查询 ,十 分 容易 出 错 。 
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作为 ASP. NET 程序 员 必须 掌握 基本 的 SQL 语句 。 

5. 实例 表 

本 书 项 目 中 采用 数据 库 名 为 SudentDb, 有 3 张 表 : Student, Course 和 SC 表 , 如 表 5-1 ~ 
Ж 5-3 所 示 。Student 表 用 于 储存 学 生 信息 表 , Course 表 用 于 储存 课程 信息 表 、SC 表 用 于 储 
存 学 生 选 课表 。 


表 5-1 Student Ж 


学 号 (sno) 姓名 (sname) 性 别 (ssex) 年 龄 (sage) 系 别 (sdept) 
201403031121 E 5 20 CS 
201403031123 王 敏 女 19 CS 
201403031124 张 硕 男 17 MA 
201403031127 问 天 男 17 IS 

# 5-2 Course X 
课程 号 (cno) 课程 名 (cname) 先行 课 (cpno) 学 分 (ceredit) 

1 数据 库 系 统 原理 5 4 

2 高 等 数学 2 

3 管理 信息 系统 1 2 

4 操作 系统 6 4 

5 数据 结构 7 4 

6 信息 方法 论 2 

7 C 语言 6 4 

表 5-3 SC 
学 号 (sno) 课程 号 (cno) | 成 绩 ( score) 学 号 (sno) 课程 号 (cno) | 成 绩 (score) 
201403031121 1 80 201403031124 1 88 
201403031121 2 78 201403031124 2 82 
201403031121 3 66 201403031124 6 58 
201403031121 4 91 
6. SQL 示例 


下 边 以 实例 形式 简单 介绍 在 应 用 程序 开发 过 程 中 使 用 较 多 的 SQL 语句 。 

注意 : SQL 语言 中 ,不 区 分 字母 大 小 写 ,可 以 根据 自己 习惯 选择 大 写 、 小 写 或 是 大 小 
混 写 。 

(1) 查询 所 有 学 生 信息 : 


БЕТЕСТ * FROM SIUCENT 


或 
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SETECT SND,SNNMP,SSEX SAGE, SEPT FROM STUDENT 
(2) 查询 学 号 为 “201215121" 的 学 生 信息 : 
SELECT * FROM STUNT WERE SND=' 201215121" 
(3) 查询 “ 刘 " 姓 学 生 信息 : 

SELECT * FROM STIUENT SRE LIKE ' 刘 $' 

(4) 按照 年 龄 顺序 查询 学 生 信息 : 

SETECT * FRM SIDUENT RER BY SGP 

(5) 查询 学 生 选 课 及 成 绩 情 况 : 


SIKT A. SNAME,B. CNNM,C. SOCRE FRM STULENT A, COURSE. B,C -S С 
WHERE A. SNO-C. SNO AND C. OD =. GD 


(6) 添加 学 生 “ "的 信息 : 

INSERT INIO SIUDENT (SNO, ЗАМЕ, SSEX, ЅАСЕ, ЅГЕРТ) VALUES () 

(7) 更 新 学 生 “” 的 信息 : 

UPDATE STUDENT SET SME ="', SSEX ="', SAE ="', SLEPT ='' WERE SNO="" 

(8) 删除 学 号 为 *" 的 学生 信 息 : 

DELETE FRM SIULENT WHRE SNO="" 

注意 ; 在 删除 语句 里 ,通常 需要 有 WHERE 条 件 , 即 限定 条 件 , 如 果 没有 则 会 删除 对 应 
表 的 所 有 数据 ,更 新 与 此 道理 相同 。 

【任务 实施 】 

第 1 步 去 微软 官网 ,下 载 SSMS(SQL Server Management Studio) 软件 , 单 击 安装 程序 ， 
开始 安装 ,弹出 安全 警告 窗口 ,如 图 5-1 所 示 。 


发 送 方 : C\Users\Administrator\Downloads\SQLM... | 


Cano) m J) 


| 国 打 开 此 文件 前 总 是 询问 m) 


图 5-1 安全 警告 窗口 


第 2 步 。 单 击 “ 运 行 "按钮 ,弹出 “程序 兼容 性 助手 "窗口 ,如 图 5-2 所 示 。 
第 3 步 单 击 “ 运 行程 序 ”" 按 钮 ,弹出 SQL Server Installation Center 窗口 ,如 图 5-3 所 示 。 
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此 程序 存在 已 知 的 兼容 性 问题 


联机 检查 Microsoft 网 站 上 是 否 有 可 用 的 解决 方案 。 如 果 找 到 了 可 用 的 解决 方案 , Windows 将 自动 
显示 列 出 了 可 采取 的 步 圣 的 网 站 。 


程序 : Microsoft SQL Server 2008 
LE 发 布 者 : Microsoft 
位 置 : Ci\Users\Administrator\Downloads\SQLManagementStudio_x64_CHT.exe 


SQL Server 安装 完成 后 ， 必须 应 用 SQL Server 2008 Service Pack 1 (SP]) 或 更 高 版 本 的 Service 
Раск, 才能 在 此 版 本 的 Windows 上 运行 SQL Server 2008, 


© maa) Rmemwanms ) жовяю )| юй | 


Г] 不 再 显示 此 消息 (O) 


图 5-2 “程序 兼容 性 助手 "窗口 


E Hardware and Software Requirements 
View the hardware and software requirements. 
Security Documentation 
View the security documentation. 
Online Release Notes 
View the latest information about the release. 


ў System Configuration Сћескег 
Launch a tool to check for conditions that prevent a successful SQL Server 
installation. 


Install Upgrade Advisor 


Upgrade Advisor analyzes any SQL Server 2005 or SQL Server 2000 
components that are installed and identifies issues to fix either before or 
after you upgrade to SQL Server 2008. 


2% Online Installation Help 

Launch the online installation documentation. 
How to Get Started with SQL Server 2008 Failover Clustering 
Read instructions on how to get started with SQL Server 2008 failover 
clustering. 

E] Upgrade Documentation 


View the document about how to upgrade to SQL Server 2008 from SQL 
{б Serverzoe Server 2000 or SQL Server 2005. 


5-3 SQL Server Installation Center 窗口 


第 4 步 单 击 Installation (安装 ) 按 钮 ,在 窗口 右边 展示 出 程序 安装 选择 项 ,如 图 5-4 
所 示 。 

第 5 步 单 击 第 一 项 ,弹出 Setup Support Rules 窗口 ,如 图 5-5 所 示 。 

ЖЕ. 如 果 出 现 图 5-5 所 示 的 Reset Computer 规则 检查 失败 , 则 需要 修改 注册 表 , 否则 
可 以 省 略 第 6 步 。 

第 6 步 ” 步 又 注册 表 的 修改 : 

(1) 选择 “程序 " 1“ 运行" 菜单 命令 ,在 “运行 "窗口 的 打开 输入 框 内 输入 “regedit”, 如 
图 5-6 所 示 。 
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New SQL Server stand-alone installation or add features to an existing 
installation. 
Launch a wizard to install SQL Server 2008 in a non-clustered environment or to 
add features to an existing SQL Server 2008 instance. 


g New SQL Server failover cluster installation 
Launch a wizard to install a single-node SQL Server 2008 failover cluster. 


Йй Add node to а SQL Server failover cluster 
FU Launch a wizard to add a node to an existing SQL Server 2008 failover cluster. 


Upgrade from SQL Server 2000 or SQL Server 2005 
Launch a wizard to upgrade SQL Server 2000 or SQL Server 2005 to SQL Server 
2008. Before you upgrade, you should run the Upgrade Advisor to detect 


Search for product updates 
Search Microsoft Update for SQL Server 2008 product updates. 


54 程序 安装 选择 项 


Long path names to files on SQL Server installation media | Passed 


5-5 Setup Support Rules 窗口 


(2) 单 击 “确定 "按钮 ,打开 注册 表 编辑 器 ,如 图 5-7 所 示 。 找 到 注册 表 项 HKEY. LOCAL 
MACHINE V SYSTEM \ CurrentControlSet V Control V Session Manager, M| 除 PendingFile- 
RenameOperations 即 可 。 

第 7 步 Hif Setup Support Rules 窗口 中 的 Rerun 按钮 ,规则 验证 都 通过 ,如 图 5-8 所 示 。 
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图 5-6 “运行 "窗口 


REG MULTI SZ 


Setup administrator 


Restart computer 

Windows Management Instrumentation (WMI) service 
Consistency validation for SQL Server registry keys 

Long path names to files on SQL Server installation media 


5-8 规则 验证 都 通过 
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第 8 步 "GE OK 按钮 ,进入 Product Key 窗口 ,本 任务 采用 的 是 Express 版 本 ,因此 不 需 


要 输入 序列 号 ,如 图 5-9 所 示 。 


Specify a free edition of SQL Server or provide a SQL Server product key to validate this 
instance of SQL Server 2008. Enter the 25-character key from the Microsoft certificate of 


@ Specify a free edition: 
Express with Advanced Services 


© Enter the product key: 


图 5-9 Product Key 窗口 


第 9 步 单 击 Next 按钮 ,进入 License Terms 窗口 ,如 图 5-10 Brzi 


MICROSOFT SQL SERVER 2008 MANAGEMENT STUDIO EXPRESS. 


一 份 由 ДНЕЙ! Microsoft 公司 (СВИ ^ 视 ” 货 用 户 所 居住 的 地 点 而 
) 之 间 所 成 立 之 饮 议 。 请 仔细 阅读 这 些 授权 人 条款。 这些 授权 休 款 适用 论 上 述 软体 ， 包括 ЖЯ 
US PEU SERIE (如 果 有 的 话 ) ° BEERA EHE] Microsoft 就 该 软体 之 


上 e 若 上 述 项 目 另 附 有 其 他 条 软 ， 则 其 他 条 软 优先 这 用 。 
Ге -SEH шат “信用 卢 同 意 接受 这 些 授权 代 款 。 若 ” 货 用 卢 不 同意 这 些 授 ~ 


Copy 


[V] I accept the license terms. 


图 5-10 License Terms 窗口 


«My 


第 10 步 ” 选 中 Iaccept the licence terms 项 , 单 击 Next 按钮 ,进入 Setup Support Files 窗 
口 ,如 图 5-11 所 示 。 


- 
The following components are required for SQL Server Setup: 
| Feature Name Status 

Setup Support Files 


图 5-11 Setup Support Files 窗口 


第 11 步 单 击 Install 按钮 ,开始 安装 前 的 检查 ,如 图 5-12 所 示 。 


The following components are required for SQL Server Setup: 
Feature Name Status 
Setup Support Files |In Progress 


5-12 ”开始 安装 前 的 检查 
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第 12 步 ”安装 检查 完 后 ,会 给 出 检查 结果 ,如 图 5-13 所 示 。 


合成 活动 模板 库 (ATL) 


不 支持 的 SQL Server 产品 
性 能 计数 闫 注册 表 配 置 单元 一 到 性 


图 5-13 检查 结果 
第 13 步 单 击 “ 下 一 步 "按钮 ,进入 “功能 选择 "窗口 ,如 图 5-14 所 示 。 


El 
共享 功能 目录 (S): 


CNProgram Files\Microsoft SQL Server\ Lj 
ы 


共享 功能 目录 (x86)(X): С\Ргодгат Files (x86)\Microsoft SQL Server 


图 5-14 “功能 选择 "窗口 
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第 14 步 ”选中 “管理 工具 -基本 ”项 , 单 击 * 下 一 步 " 按 钮 ,进入 "磁盘 空间 要 求 "窗口 ,如 
图 5-15 所 示 。 


5 © изи c: RE 982 мв. 3 74172 MB 可 用 
一 ЖЖ (CN: RENE 587 MB 
C amaan (CAProgram Files\Microsoft SQL Server): RR 395 MB 


图 5-15 “磁盘 空间 要 求 "窗口 
第 15 步 单 击 “ 下 一 步 " 按 钮 ,进入 “错误 和 使 用 情况 报告 "窗口 ,如 图 5-16 所 示 。 


指定 您 愿 富生 动 发 送 到 Microsoft SQL Server 


Ж Windows 和 SQL Server ВАЕ АБЕ Microsoft 或 各 公司 的 报 和 好 务 器 。 这 设置 人 和 用 于 
Г 以 无 用 户 交互 方式 运行 的 服务 (W)- 


功能 使 用 人情 部 数 所 发 送 到 Microsof。 功 能 全 用 情况 歼 所 包括 有 关 您 的 顶 件 配置 及 您 对 
“Мотой BE RUBBER ауа (Р, 


[pr m 


图 5-16 “错误 和 使 用 情况 报告 "窗口 
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第 16 步 单 击 “ 下 一 步 "按钮 ,进入 “安装 规则 ”窗口 ,如 图 5-17 所 示 。 


ЗМЕЯ. БЫ: 8, 90. ФЕ 0. БРЫ 3, 


SQL Server 2000 Analysis Services (64 位 ) 安 装 操作 
实例 名 


图 5-17 “安装 规则 ”窗口 
第 17 步 单 击 “ 下 一 步 "按钮 ,进入 “准备 安装 "窗口 ,如 图 5-18 所 示 。 


上 实例 目录 : CAProgram Files\Microsoft SQL Server\ 
共享 组 件 根 目录 
[лен CAProgram Files\Microsoft SQL Server\ 
一 共享 功能 (WOW64) 目 录 : CAProgram Files (x86)\Microsoft SQL Server 


使 用 情况 报告 : False 
错误 报告 : False 


配置 文件 路 径 : 
CiVProgram Files\Microsoft SQL Server\100\Setup Bootstrap\Log\20140731_065736\Configurati 


图 5-18 “准备 安装 "窗口 
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第 18 步 单 击 “下 一 步 "按钮 ,进入 "安装 进度 "窗口 ,如 图 5-19 所 示 。 


@ eI 由 -二 本 
© [soL вые SDK 


图 5-19 “安装 进度 "窗口 


第 19 步 ”等 安装 完成 ,会 出 现 * 下 一 步 "按钮 , 单 击 “ 下 一 步 "按钮 ,进入 "完成 "窗口 ,如 
图 5-20 所 示 。 单 击 “ 关 闭 ” 按钮 ,SQL Server Management Studio 安装 完成 。 


Microsoft Update IE SQL Server 2008 的 更 新 的 信息 , 请 访问 Microsoft 
Undate 网 站 <httn://ao.microsoftcom/falink/?1inkid=108409> . 网 直 为 


Сз 


520 “完成 "窗口 
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以 上 为 SQL Server Management Studio 的 安装 ,下 边 是 SQL Server Management Studio 的 
使 用 ,主要 讲解 通过 它 操 作 数 据 库 。 

第 1 步 选择 “开始 "1“ 所 有 程序 ”|Microsoft SQL Server 2008 | SQL Server Management 
Studio 菜单 命令 ,如 图 5-21 所 示 。 

第 2 步 单 击 打开 SQL Server Mangement Studio, 如 图 5-22 所 示 。 


Ji. Java Development Kit ^ 
J MathType 6 
J Microsoft Office 
Ji Microsoft Silverlight 
J Microsoft Silverlight 3 SDK - 中 文 简 
j Microsoft SQL Server 2008 
Ча SQL Server Management Studio. 
加 导入 和 导出 数据 (32 位 ) 
Ц 导入 和 导出 数据 (64 位 ) 
J Integration Services 
J ESIA 
Ji Microsoft Sync Framework 
J Microsoft Visual Studio 2010 
J MyEclipse 
Ji MysQL 是 EB) 


用 户 名 四 [SDmI-2014050TGI VAdnini str ator + 


记 住 密码 如 


+ sm 
EZA Р] [аж ава) [зао о 


[| 5-21 启动 菜单 图 5-22 登录 界面 


第 3 步 ” 服 务 器 名 称 设置 为 "(local) ”或 “.”, 身 份 验证 设置 为 "Windows 身份 验证 ”, 单 
击 “ 连 接 " 按 钮 ,登录 到 数据 库 服务 器 ,如 图 5-23 所 示 。 
Ца Microsoft SQL Server Management Studio š [eis 


RHA BSO GUN) IAM SOW #50 MWH 
Daman D O g hal 


0-8 = Y Z) Š 


图 5-23 登录 到 数据 库 服务 器 


第 4 步 ” 右 击 “ 对 象 资源 管理 器 "中 的 “数据 库 " 结 点 ,从 弹出 的 快捷 菜单 中 选择 “新 建 
数据 "命令 ,打开 “新 建 数 据 库 ” 窗 口 , 如 图 5-24 所 示 。 

第 5 步 输入 数据 库 名 称 StudentDB, 单 击 “ 确 定 ” 按 钮 ,数据 库 创建 成 功 ,如 图 5-25 
所 示 。 
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Р 5-24 “新 建 数据 库 "窗口 


第 6 步 ”展开 studentDB 数据 库 , 右 击 “ 表 ”, 从 弹出 的 快捷 菜单 中 选择 “新 建 表 ”命令 ， 
打开 “表格 创建 "窗口 ,如 图 5-26 所 示 。 

第 7 步 ” 输入 列表 ,设置 数据 类 型 ,设置 sno 为 主键 ,选中 表 头 , 右 击 ,从 弹出 的 快捷 菜 
单 中 选择 “保存 ” ,弹出 “选择 名 称 ” 对 话 框 ,如 图 5-27 所 示 。 


i90o-|89 а T [z] Š //SDWM-20140807GYV-DB - dbo.Table_1" | <x 
日 图 (local) (SQL Server 10.0.2531 - SDWM-20| эё 数据 类 型 яма 
o Fa 数据 库 а vade —— 
= Га хажат z ш 
田 国 db.oxhr ded 
& [J studentDB sdept w 
m Ca 数据 库 关系 图 m 
sag 
га 系统 表 
= Га 视图 Гел | 
Ca 同义词 == 
m a HARE 图 5-26 “表格 创建 "窗口 
田 Service Broker 
вш 安全 性 
= Ca 安全 性 
= Са 服务 高 对象 
m Ca 复制 
вош 管理 
| = — 
图 5-25 数据库 创建 成 功 图 5-27 “选择 名 称 ”对 话 框 
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第 8 步 输入 “Student” , 单 击 “ 确 定 ”" 按 钮 ,数据 库 中 Student 表 创 建成 功 。 
第 9 步 ” 在 “对 象 资源 管理 器 "中 找到 student 表 , 右 击 ,从 弹出 的 快捷 菜单 中 选择 “编辑 
前 200 行 ”, 打 开 表 数据 编辑 窗口 ,如 图 5-28 所 示 。 


“ SDWM-20140507GYN..DB - dbo.Student 
sno sname sage зех 
»* ми ми ми ми 


‹ ] * 


к 41 n|» M ye | @ 


图 5-28 表 数 据 编辑 器 窗口 


第 10 步 输入 学 生 数 据 , 右 击 表 头 上 的 表 名 处 ,从 弹出 的 快捷 菜单 中 选择 “保存 "或 者 
“KA” ,关闭 前 会 提示 是 否 保存 ,如 图 5-29 所 示 。 


SSex sage sdept 
b — [201215121 Е в 30 cs 
201215122 WR x 19 cs 
201215123 £ x 18 MA 
201215125 3k 男 19 Is 
ж |ми ми ми ми 


Kj п, 
м 41 141» MP |G | | 


图 5-29 保存 的 表 


第 11 步 Ят studentDB 数据 库 , 从 弹出 的 快捷 菜单 中 选择 “任务 " |” 分离" 命令 ,如 
图 5-30 所 示 。 

第 12 步 ”在 第 11 步 中 单 击 * 分 离 " 按 钮 ,打开 “分离 数据 库 窗 口 ,如 图 5-31 所 示 。 

注意 : 如 果 此 处 不 选中 “删除 连接 "选项 ,可 能 会 出 现 错误 ,如 图 5-32 所 示 。 

第 13 步 ” 选 中 “删除 连接 "选项 , 单 击 “ 确 定 " 按 钮 ,如 图 5-33 所 示 ,studentDB 数据 库 被 
分 离 ,被 分 离 的 数据 库 在 对 象 资源 管理 器 中 无 法 找到 。 

第 14 步 ” 右 击 “ 对 象 资源 管理 器 "中 的 “数据 库 ” 结 点 ,从 弹出 的 快捷 菜单 中 选择 “ 附 
加 ”命令 ,如 图 5-34 所 示 。 
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н; 
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иж 
[wx] 
531 “分 离 数据 库 " 窗 口 
Microsoft SQL Server 
分 离 数据 库 对 于 服务 器 "SDWM-20140507GY 头 败 。 (Microsoft.SqiServer.Smo) 
неве: 
| 执行 TansactsQL 语句 或 批 处 理 时 发 生 了 异常 。 (erosoft.sdServer.Connectoninfo) 
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9-238 [ we J 


图 5-32 出 错 提示 
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图 5-33 ”被 分 离 的 数据 库 无 法 找到 


日 国 (local) (SQL Server 10.0.2531 - SDWM-20 


新 建 数据 库 (N).… 
ИЗДА)... 

还 原 数 据 库 (R).… 

还 原文 件 和 文件 组 (E).… 


启动 PowerShell(H) 
报表 (P) 
局 新 (所 


rM , 
图 5-34 “附加 ”快捷 菜单 


第 15 步 ” 选择“ 附加 "命令 ,打开 “附加 数据 库 窗口 ”, 如 图 5-35 所 示 。 
第 16 步 单 击 “ 添 加 "按钮 ,打开 “定位 数据 库 文件 "窗口 ,如 图 5-36 所 示 。 
第 17 步 ” 找 到 并 选中 studentDB. mdf 文件 , 单 击 “ 确 定 " 按 钮 ,数据 库 附 加 成 功 ,在 “对 
象 资源 管理 器 "又 可 以 找到 “studentDB" 数 据 库 了 。 
第 18 步 ”在 “对 象 资源 管理 器 "中 找到 studentDB 数据 库 , 右 击 , 从 弹出 的 快捷 菜单 中 
选择 “新 建 查询 ”菜单 项 ,打开 “查询 器 "窗口 ,如 图 5-37 所 示 。 
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图 5-35 “附加 数据 库 窗 口 
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图 5-37 


“查询 器 "窗口 


第 19 步 ”在 "查询 器 "中 输入 SQL ifi "select * from student" , 单 击 “ 执 行 "按钮 ,执行 
SQL 语句 ,在 SQL 语句 的 下 边 出 现 查 询 结 果 , 如 图 5-38 所 示 。 


SQLQuery3.sql - (l..dministrator (52))*| 
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【任务 小 结 】 


图 5-38 输入 查询 条 件 后 得 到 的 结果 


本 任务 演示 了 数据 库 客户 端 软件 SSMS 的 安装 及 使 用 ,并 简单 演示 了 在 SSMS 中 如 何 操 


作 数 据 库 以 及 执行 SQL 语句 。 本 任务 中 SQL 语言 


法 一 一 演示 ,需要 读者 自己 在 SSMS 客户 端 中 多 练习 。 


【拓展 提高 】 
1. 聚集 函数 


SQL 中 提供 了 以 下 聚集 函数 。 


(1) Count( * ) : 统计 表 中 的 记录 个 数 。 
(2) Sum( 列 名 ) : 计算 列 值 的 总 和 。 
(3) Avg( 列 名 ) : 计算 列 值 的 平均 值 。 


一 个 重点 ,但 是 由 于 SQL 知识 杂碎 ,无 
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(4) Min( 列 名 ) : 计算 列 值 的 最 小 值 。 

(5) Max( 列 名 ) : 计算 列 值 的 最 大 值 。 

使 用 示例 : 

(1) 查 询 学 生 表 中 有 多 少 条 记录 : 

Select cant (* ) fram Student 

(2) 查询 课程 的 总 学 分 : 

Select sm() frcm Course 

2. 分 组 

分 组 是 查询 结果 按照 某 一 列 或 多 列 的 值 进行 分 组 , 值 相等 的 为 一 组 ,在 SQL 中 分 组 是 
由 Group By 子 句 实现 的 。 分 组 子 名 常常 和 聚集 函数 一 同 使 用 。 

使 用 示例 : 

(1) 查询 各 个 课程 的 被 选 情况 

SELECT CWO, COUNT (СЮ) FROM SC GROUP BY QNO 

(2) 查询 课程 被 选修 情况 : 

SELECT CNO, COUNT ( * ) GRM SC GROUP BY QNO 

(3) 查询 选修 了 3 门 以 上 课程 的 学 生 学 号 : 

SELECT SNO GROM SC GROUP BY SNO HAVING OOUNT(* ) >3 

3. 存储 过 程 

存储 过 程 (Stored Procedure ) 是 在 大 型 数据 库 系 统 中 ,一 组 为 了 完成 特定 功能 的 SQL iis 
句 集 ,经 编译 后 存储 在 数据 库 中 ,用 户 通过 指定 存储 过 程 的 名 字 并 给 出 参数 ( 如 果 该 存储 过 
程 带 有 参数 ) 来 执行 它 。 存 储 过 程 是 数据 库 中 的 一 个 重要 对 象 ,任何 一 个 设计 良好 的 数据 
库 应 用 程序 都 应 该 用 到 存储 过 程 。 

(1) 创建 存储 过 程 : 

create proosdure sp name 

@ [参数 名 ] [类 型 ],@ [参数 名 ] [类 型 ] 


as 


begin 
end 
以 上 格式 还 可 以 简写 成 : 


create proc sp name 
@ [参数 名 ] 类 型 ],8 [参数 名 ] РЕ] 
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(2) 调用 存储 过 程 : 

exec sp name [参数 名 ] 

(3) 删除 存储 过 程 : 

drop procedure sp name 

注意 : 不 能 在 一 个 存储 过 程 中 删除 另 一 个 存储 过 程 ,只 能 调用 另 一 个 存储 过 程 。 
任务 5-2 使 用 ADO. NET 操纵 学 生 信息 


【任务 描述 】 
客户 要 求 小 王 开发 一 个 学 生 信息 管理 系统 ,最 基础 的 就 是 学 生 信息 的 呈现 以 及 在 呈现 
的 基础 上 对 学 生 信 息 进行 修改 和 删除 。 


【任务 目的 】 

掌握 ADO. NET 的 核心 类 以 及 类 的 常用 属性 和 方法 。 

掌握 ADO. NET 的 开发 过 程 。 

掌握 DataReader 和 DataSet 读 取 数据 库 的 差别 。 

掌握 Command 对 象 执行 数据 库 的 类 型 。 

【任务 分 析 】 

本 任务 是 在 连接 数据 库 的 基础 上 , 读 取 和 更 新 数据 库 的 数据 。 大 多 数 高 级 编程 语言 
于 基本 的 数据 库 访问 操作 比较 类 似 , ADO. NET 也 提供 了 类 似 的 处 理 方式 ， pe 
.NET 提供 了 一 个 其 他 高 级 语言 不 具有 的 功能 , 读 取 数据 直接 绑 定 到 网 页 控件 ,特别 是 
DataSet 和 绑 定 控件 的 配合 使 用 ,更 是 功能 强大 使 用 方便 。 

本 任务 使 用 ADO. NET 技术 访问 查询 操纵 数据 库 ,使 用 到 了 ADO. NET 的 核心 类 。 
ADO. NET 访问 数据 库 的 知识 比较 规范 ,是 同一 个 套路 , 刚 开始 感觉 比较 难 ,熟悉 之 后 比较 简单 。 

【基础 知识 】 

1. ADO. NET 基础 

ADO. NET 有 两 个 核心 组 件 : .NET 数据 提供 者 和 DataSet 数据 集 。 其 中 . NET 数据 提供 
者 是 数据 库 的 访问 接口 ,负责 数据 的 链接 和 数据 库 的 操作 ,完成 数据 提供 者 的 对 象 包括 
Connection 对 象 Command 对 象 ,DataAdapte 对 象 DataReader XJ Z ; DataSet 数据 集 是 一 个 内 
存 中 的 数据 集 , 可 以 看 作 是 一 个 把 数据 库 搬 迁 到 内 存 中 ,虚拟 的 数据 库 。 

. NET 中 常用 的 数据 提供 程序 有 4 种 : 

(1) SQL Server 数据 提供 程序 ,适用 于 SQL Server 数据 库 。 

(2) OLE DB 数据 提供 程序 ,适用 于 所 有 提供 了 OLE DB 接口 的 数据 源 ,如 Access 等 。 

(3) ODBC 数据 提供 程序 ,适用 于 所 有 提供 了 ODBC 控件 的 数据 源 。 

(4) Oracle 数据 提供 程序 ,适用 于 Oracle 数据 库 。 

以 上 4 种 数据 提供 者 都 有 自己 对 应 的 Connection 对 象 .Command 对 象 DataReader 对 
象 、 DataAdapter 对 象 。 比 如 SQL Server 数据 提供 程序 的 对 象 为 SqlConnection 对 象 、 
SqlCommand 对 象 SqlDataReader 对 象 SqlDataAdapter 对 象 。4 种 数据 提供 程序 中 ,ASP . 
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NET 技术 中 ,通常 使 用 SQL Server 数据 提供 程序 ， 

4 个 核心 对 象 的 作用 如 下 。 

(1) Connection 对 象 : 用 于 建立 与 特定 数据 源 的 连接 。 

(2) Command 对 象 : 用 于 执行 SQL 语句 ,如 添加 ,修改 .删除 数据 等 。 

(3) DataReader 对 象 : 用 于 返回 一 个 来 自 Command 对 象 的 只 读 只 能 向 前 的 数据 流 。 

(4) DataAdapter 对 象 : 用 于 把 数据 从 数据 源 中 读 取 到 一 个 内 存 表 中 ,以 及 把 内 存 表 中 
的 数据 写 回 一 个 数据 源 , 它 是 一 个 双向 通道 。DataAdpater 提供 了 DataSet 对 象 和 数据 源 的 

2. 常用 对 象 

本 书 以 SQL Server 数据 提供 程序 为 例 , 讲 解 ADO. NET 的 使 用 ,其 他 的 数据 源 和 它 的 使 
用 几乎 一 模 一 样 ,只 需要 把 SQL Server 的 对 象 更 改 为 数据 源 的 ADO. NET 对 象 即 可 。 

(1) SqlConnection 对 象 。SqlConnection 对 象 是 ADO. NET 提供 的 访问 SQL Server 数据 
库 的 连接 类 ,通过 它 可 以 和 数据 库 建 立 连接 。 

SqlConnection 对 象 在 连接 SQL Server 数据 库 时 ,需要 设置 连接 字符 串 , 这 是 
SqlConnection 对 象 的 核心 属性 。 连 接 字符 串 包含 多 个 参数 ,常用 参数 如 表 5-4 所 示 。 


表 5-4 SqlConnection 对 象 主要 属性 


名 Ж 说 HH 
DataSource/Server 数据 库 实例 的 名 称 或 网 络 地 址 ,本 地 为 (local) 
Initial Catalog/Database 数据 库 名 称 
Trusted. Connection/ Integranted Security 是 否 使 用 Windows 账户 进行 身份 验证 
Password/Pwd 数据 库 登录 密码 
User ID 数据 库 登 录用 户 名 


SqlConnection 对 象 的 主要 方法 如 表 5-5 所 示 。 
# 5-5 SqlConnection 对 象 主要 方法 


名 Ж 说 明 
Open 打开 连接 
Close 关闭 连接 


(2) SqlCommand 对 象 。SqlCommand 对 象 用 来 执行 各 种 SQL 命令 ,常用 的 命令 有 
Select „Insert , Update 和 Delete 等 。 


SqlCommand 对 象 的 属性 如 表 5-6 所 示 。 
表 5-6 SqICommand 对 象 主要 属性 


名 Ж 说 — H 
CommandText 获取 或 设置 Command 对 象 所 要 在 数据 源 上 执行 的 SQL 语句 或 存储 过 程 
DIEM 设置 或 获取 Command 命令 执行 并 产生 一 个 错误 前 等 待 时 间 ,类 型 为 nt, 单位 为 秒 ， 
ommand теси 默认 值 为 30。 
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续 表 


名 Ж 说 明 
C dT 表示 CommandText 值 的 类 型 ,其 值 可 能 为 :Text( SQL) „StoredProcedure ( 存储 过 程 ) 、 
SES TableDireet( 返回 所 有 列 的 表 名 ) 
Connection 设置 或 返回 与 该 命令 相关 的 Connection 对 象 
p. А -个 Parameter 对 象 的 集合 。 可 以 通过 向 该 集合 中 添加 新 的 Parameter 对 象 ,在 执行 
u—€— Command 命令 时 传递 参数 
Transaciton 返回 该 命令 所 处 的 Transaction 对 象 


SqlCommand 对 象 的 方法 如 表 5-7 所 示 。 
表 5-7 SqlCommand 对 象 主要 方法 


名 Ж 说 明 
Cancel 取消 所 执行 的 命令 
CreateParameter 创建 SQL 语句 中 包含 的 参数 对 象 
ExecuteNonQuery 执行 没有 返回 值 的 SQL 语句 
ExecuteReader 执行 结果 返回 一 个 数据 流 
ExecuteScalar 返回 单个 值 。 常 常用 于 返回 统计 结果 


SqlCommand 通过 ExecuteReader 方法 来 执行 数据 查询 (Select 语句 ), 通过 
ExecuteNonQuery 方法 来 执行 数据 操作 (Insert , Update „Delete 语句 ) 。 
小 提示 : ExecuteReader 和 ExecuteNonQuery 针对 不 同 的 SQL 语句 , 千 万 不 能 用 错 ,否则 
程序 一 定 错 误 。 
(3) SqlDataReader 对 象 。SqlDataReader 对 象 是 一 种 数据 流 ,通过 该 对 象 返 回 的 查询 结 
果 是 只 读 并 且 只 能 向 前 读 ,不 可 以 通过 该 对 象 来 更 新 数据 库 , 也 不 可 以 向 后 读数 据 。 
SqlDataReader 对 象 常用 属性 如 表 5-8 所 示 。 


表 5-8 SqlDataReader 对 象 常用 属性 


名 Ж 说 明 
IsClosed 获取 状态 true 或 false 
FieldCount 获取 字段 数目 
Item 获取 或 设置 字段 内 容 
RecordsAffected 获取 执行 insert update 和 delete 语句 后 有 多 少 行 受到 影响 


SqlDataReader 对 象 常用 方法 如 表 5-9 所 示 。 
(4) SqlDataAdapter 对 象 。SqlDataAdapter 对 象 是 数据 适配器 对 象 ,主要 负责 处 理 数据 
源 格式 和 DataSet 使 用 的 格式 之 间 的 转换 ,在 数据 访问 中 作用 至 关 重 要 , 它 是 数据 源 和 
DataSet 之 间 的 桥梁 。 该 对 象 可 以 读 取 、 添 加 、 更 新 和 删除 数据 源 中 的 记录 。 
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表 5-9 SqlDataAdapter 对 和 象 常用 方法 


名 Ж 说 明 
Close 关闭 
getBoolean( ordinal ) 获取 ordinal + 1 列 的 内 容 , 返 回 值 为 boolean 类 型 
GetDataTypeName( ordinal) 获取 ordinal + 1 列 的 数据 源 类 型 名 称 
getFileType( ordinal ) 获取 ordinal + 1 列 的 数据 类 型 
GetName( ordinal ) 获取 ordinal + 1 列 的 字段 名 称 
getOrdinal( ordinal) 获取 ordinal + 1 列 的 字段 列 号 
GetValue( ordinal ) 获取 ordinal + 1 列 的 内 容 
GetValues( values) 取得 所 有 字段 内 容 , 并 将 内 容 放 在 values 数组 中 
IsDBNullordinal ( ) 判断 ordinal + 1 列 是 否 为 空 ,返回 Boolean 
Read 读 取 下 一 条 数据 ,如 果 没 有 ,将 返回 false 


SqlDataAdapter 对 象 的 主要 属性 如 表 5-10 所 示 。 


名 Ж 


# 5-10 SqlDataAdapter 对 象 的 主要 属性 
说 明 


DeleteCommand 


获取 或 设置 一 个 Transact-SQL 语句 或 存储 过 程 ,以 从 数据 源 删 除 记 录 


InsertCommand 


获取 或 设置 一 个 Transact-SQL 语句 或 存储 过 程 ,以 从 数据 源 插入 新 记录 


SelectCommand 


获取 或 设置 一 个 Transact-SQL 语句 或 存储 过 程 ,以 从 数据 源 选择 记录 


UpdateCommand 获取 或 设置 一 个 Transact-SQL 语句 或 存储 过 程 ,以 从 数据 源 修改 记录 
TableMappings SqlDataAdapter 用 来 将 查询 的 结果 映射 到 DataSet 的 集合 信息 中 
ContinueUpdate 控制 SqlDataAdapter 在 遇 到 一 个 错误 之 后 是 否 继续 提交 更 改 


SqlDataAdapter 对 象 的 主要 方法 如 表 5-11 所 示 。 


表 5-11 SqlDataAdapter 对 象 主要 方法 


名 K 说 明 
Fill 执行 存储 于 SelectCommand 中 的 查询 ,并 将 结果 存储 在 DataTable 中 
i 为 存储 在 SelectCommand 中 存储 的 查询 获取 架构 信息 。 获 取 查 询 中 各 列 名 称 和 数 
С 据 类 型 
GetFillParameters H SelectCommand 对 象 获取 一 个 包含 着 参数 的 数组 
Updte 向 数据 库 提交 存储 在 DataSet( EÈ DataTable ,DataRows) 中 的 更 改 。 该 方法 会 返回 一 


个 整数 值 ,其 中 包含 着 在 数据 存储 中 成 功 更 新 的 行 数 


SqlDataAdapter 对 象 的 主要 事件 如 表 5-12 所 示 。 
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表 5-12 ”SqlDataAdapter 对 象 主要 事件 


名 Ж 说 “B 
FillError 当 SqlData Adapter 遇 到 填充 DataSet 或 DataTable 的 一 个 错误 时 ,该 事件 被 触发 
RowUpdated 向 数据 库 提 交 一 个 修改 的 行 之 后 触发 
RowUpdating 向 数据 库 提交 一 个 修改 的 行 之 前 触发 


SqlDataAdapter 对 象 构造 方法 有 多 个 ,其 使 用 方式 也 就 有 多 种 。 


(D sqlDatancaper sda -new SqlDatandaper () ; 

Sda.SelectCammnd new SqlCamand ("select * fram student", оп); 

(9) sqCamand ard =пем SqlCammand("select * fram student", oom) ; 

SqlDataAdaper sda -new SqlDataPcaper (ато) ; 

(3) SclDataAdaper sda -new SqlDataMdeper ("select * fram student", conn) ; 

@) SclDataAdaper sda -new SglDataMdeper ("select * from student", conn); 

此 处 url 是 数据 源 连接 字符 串 。 

(5) DataSet 对 象 。DataSet 类 似 于 一 个 小 型 的 关系 数据 库 , 包 含 一 个 或 多 个 表 。 数 据 存 
ИЕ DataTable 对 象 中 ,每 个 DataTable 对 象 包含 DataRow 对 象 的 集合 .DataColumn 对 象 的 集 
AF Constraint 对 象 的 集合 。 

DataSet 对 象 是 DataTable 对 象 的 集合 ,并 且 管 理 DataTable 之 间 的 关系 ,人 允许 引用 完整 
性 ,级 联 更 新 等 。 

DataSet 对 象 是 一 个 容器 ,可 以 从 数据 适配器 执行 的 SQL 命令 或 存储 过 程 中 填充 数据 ， 
DataSet 的 设计 是 为 了 实现 独立 于 任何 数据 源 的 数据 访问 。 

DataSet 对 象 的 常用 属性 如 表 5-13 所 示 。 


表 5-13 DataSet 对 象 常用 属性 


# Ж 说 明 
CaseSensitive 用 于 控制 DataTable 中 的 字符 串 比 较 是 否 区 分 大 小 写 
DataSetName 当前 的 DataSet 的 名 称 。 如 果 不 指定 , 则 该 属性 设置 为 NewDataSet 
HasError 表示 DataSet 中 的 DataRow 对 象 是 否 包含 错误 
DesignMode 如 果 在 设计 时 使 用 组 件 中 的 DataSet , DesignMode 返回 True ,否则 返回 False 
Tables 检查 现 有 的 DataTable 对 象 。 
Relations 返回 一 个 DataRelationCollection 对 象 


小 提示 : 通过 索引 方式 访问 DataTable 具有 更 好 的 性 能 。 

DataSet 对 象 的 常用 方法 如 表 5-14 所 示 。 

(6) DataTable 对 象 。DataTable 对 象 也 是 ADO. NET 的 核心 对 象 之 一 ,该 对 象 是 元 数据 
和 数据 的 集合 ,元 数据 通过 DataColumn 对 象 和 Constraint 对 象 的 集合 描述 ,数据 包含 在 
DataRow 对 象 的 集合 中 。 DataTable 可 以 独立 存在 ,也 可 以 作为 DataSet 的 一 部 分 。 

DataTable 的 常用 属性 如 表 5-15 所 示 。 
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名 Ж 


#514 DataSet 对 和 象 常用 方法 
说 明 


Clear 清除 DataSet 中 的 所 有 对 象 ,该 方法 比 释放 一 个 DataSet 然后 再 创建 一 个 DataSet 效率 要 高 


CetChanges 新 的 行 


返回 与 原 DataSet 对 象 具有 相同 结构 的 新 Dataset, 并 且 还 包含 原 DataSet 中 的 所 有 挂 起 更 


HasChange | 表示 DataSet 中 是 否 包含 挂 起 更 改 的 DataRow 对 象 


Reset 将 DataSet 返回 为 未 初始 化 状态 


# 5-15 DataTable 对 象 常用 属性 


名 Ж 说 明 

Rows 获取 属于 该 表 的 行 的 集合 

Columns 获取 属于 该 表 的 列 的 集合 

PrimaryKey 指示 哪 一 列 或 哪 几 列 构成 主键 

DefaultView 获取 可 能 包含 筛选 视图 或 游标 位 置 的 表 的 自 定义 视图 
TableName 获取 或 设置 DataTable 的 名 称 


DataTable 对 象 的 常用 方法 如 表 5-16 所 示 。 


35-16 DataTable 对 象 常用 方法 


名 Ж 说 — HH 
ImportRow 添加 来 自 具有 相同 架构 的 其 他 DataTable 中 的 DataRow 的 副本 
Select 返回 根据 提供 的 参数 进行 排序 和 筛选 的 DataRow 对 象 的 数组 
Clear 清除 DataTable 里 的 所 有 数据 


3. ADO.NET 过 程 


ADO. NET 数据 库 应 用 程序 的 开发 流程 步骤 如 下 。 
第 1 步 ”创建 数据 库 ,创建 相应 的 表 , 录 入 相应 数据 。 
第 2 步 导入 相应 的 命名 空间 。 导 入 ADO. NET 命名 空间 语法 如 下 : 


using System.Data; 
using System.Data.SqlClient; 


注意 : 在 没有 导入 命名 空间 的 情况 下 ,使 用 命名 空间 下 的 对 象 ,系统 会 报错 ,并 且 编 写 


代码 也 不 会 给 出 提示 。 


如 果 使 用 的 对 象限 于 SqlConnection 对 象 „SqlCommand SqlDataReader ,SqlDataAdapter 对 
象 , 则 只 需要 第 二 句 ,如 果 使 用 DataSet 对 象 , 则 需要 加 第 一 句 。 
第 3 Mi Connection 对 象 创建 与 数据 库 的 连接 。 语 法 如 下 : 


SglConnection conn =new SqiConnecticn (url) ; 


„Ад 


其 中 ud 是 连接 字符 串 ,比如 : 


url ="Data Source =.;Initial Catalog =strentIb; Integrated Security -True"; 
第 4 步 通过 Commad 对 象 对 数据 库 执 行 SQL 语句 。 


SqlCamand amd =пем SqlCamand (sql, conn) ; 
ard. ExecuteNorQuery () ; 


第 5 步 通过 DataReader 对 象 读 取 数 据 源 中 数据 。 


Sql DataReader reader =amd.ExecutsReader () ; 
while (reader .Read() ) 
{ 
Response. Write (reader ["sro"]) ; 
Response. Write (reader ["snane"]) ; 
Response. Write (reader ["ssex"]) ; 
Response. Write (reader ["sage"]) ; 
Response. Write (reader ["sdept"]) ; 
) 
第 6 步 关闭 数据 库 的 连接 ,释放 DataReader 对 象 。 


reader.Cloase(); 
omn.Close(); 


读 取 数据 库 的 对 象 除 了 DataReader 外 ,还 有 DataSet 对 象 , 它 和 DataAdapter 对 象 一 起 来 
完成 读 取 数 据 源 , 即 第 5 步 可 以 通过 DataSet 读 取 数 据 。 如 果 是 数据 更 新 操作 , 则 没有 第 
5, 

DataSet 对 象 和 DataAdapter 对 象 读 取 数据 库 : 

string url -"Data Source =. ; Initial Catalog -studentTb; Integrated Security -True"; 

SalConnection com new SqlConnecticn (url); 

SqlCamand amd new SqlCamend("select * fram Student", conn) ; 
sqlpatandapter sda -new SqlDataAdapter (ard) ; 

DataSet ds =пем DataSet () ; 

Sda.Fill(ds); 


4. ASP . NET 中 SQL 语句 

SQL 语句 在 ASP . NET 中 是 一 个 字符 串 , Commad 对 象 会 把 这 个 字符 串 作 为 参 
数 。SQL 语句 本 身 并 不 难 写 ,但 是 在 ASP . NET 中 ,时 常会 和 变量 穿插 在 一 起 ,因此 对 于 初 
学 者 是 一 个 难点 ,也 是 一 个 很 容易 出 错 的 地 方 。 在 ASP . NET 中 使 用 数据 库 的 方式 有 三 种 : 

(1) 拼写 SQL 语句。 把 SQL 语法 与 C# 中 的 变量 拼 在 一 起 ,形成 一 条 SQL 语句 ,比如 ， 
学 生 的 学 号 姓名, 性别, 年龄 和 系 别 5 个 变量 ,目前 这 5 个 变量 都 已 经 赋值 ,现在 要 把 数据 
保存 到 数据 库 ,拼凑 SQL 语句 为 : 

string sq =" insert into student values ('" +sno +"', '" 4sname +"! , '" +ssex i", 

"sage +", '" tedept enn; 

这 里 其 实 就 是 字符 串 的 连接 ,但 是 由 于 SQL 语句 中 字符 串 使 用 单 引 号 ,而 C# 语 言 中 使 
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用 字符 串 使 用 双 引 号 ,因此 就 出 现 了 例子 中 的 情况 ,很 多 引号 在 一 起 了 ,这 对 初学 者 是 个 考 
验 ,需要 认真 仔细 才能 拼写 无 误 。 

小 技巧 : 拼凑 SQL 语句 很 容易 出 错 , 为 了 在 出 错时 能 够 及 时 发 现 ,可 以 把 拼凑 好 的 SQL 
语句 输出 ,程序 出 错时 ,检查 SQL 语句 ,可 以 快速 定位 修订 错误 。 

(2) 参数 法 。 由 于 第 一 种 方法 复杂 且 容 易 出 错 , 因 此 目前 使 用 较 多 的 是 参数 法 ,该 方法 
把 数据 在 SQL 语句 中 定义 为 参数 ,因此 这 种 SQL 语句 和 普通 的 SQL 语句 无 异 , 在 SQL 执行 
前 对 参数 赋值 即 可 。 

参数 法 的 用 法 是 Command 对 象 的 Parameters 属性 ,这 个 属性 是 一 个 SqlParameter 对 象 
的 数组 ,具体 使 用 如 下 。 


string sql -"insert into student values (@sno,@sreme, 6 s5ex, 8 sage, збері)"; 
Sql Parameter paraNamel -new Sql Parameter ("8 sro", sno) ; 
Sal Parameter paraName2 -new Sql Parameter ("Gsname", snare); 
Sql Parameter paraName3 -new Sql Parameter ("8ssex", ssex); 
Sal Parameter paraName4 -new Sql Parameter ("@sage", sage) ; 
Sql Parameter paraName5 -new Sql Parameter ("8 sdept", sdept); 
ard. Parameters Ad (paraNamel ) ; 
ard. Parameters .Pdd (paraName2) ; 
ard. Parameters .д00 (paraName3) ; 
ard. Parameters Aci (paraName4) ; 
ard. Parameters .Acd (paraName5) ; 


其 中 ,cmd 是 Command XJ , sno „sname ,ssex „sage 和 sdept 是 变量 。 

(3) 存储 过 程 。 在 ADO. NET 中 ,还 可 以 调用 存储 过 程 , 这 种 方法 应 用 不 如 参数 法 广 ， 
并 且 难 度 也 大 ,因此 放 到 拓展 提高 中 讲解 。 

【任务 实施 】 

第 1 步 。 新建 网 站 chap5-2 ,添加 新 项 * Web 窗 体 ”, 使 用 默认 名 Default. aspx, fE Default. 
aspx 由 源 代码 视图 切换 到 设计 视图 。 

第 2 步 ”向 Default. aspx 窗 体 拖 放 控 件 , 控 件 为 5 个 Label .5 个 TextBox 和 1 个 Button 
控件 ,如 图 5-39 所 示 。 


PE Defaultaspx* x 
1 iol 
Label 
Label 
Label 
Label! | 
Label 


Button 


ой | 口 拆 分 | 回 源 | А огт огт1> |[<div>| <asp:ButtonsButtonl> 


图 5-39 网 页 设计 效果 
第 3 步 ” 修改 控 件 的 属性 。 按 照 表 5-17 修改 控件 属性 。 
表 5-17 控件 属性 
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控 件 属性 及 属性 值 Eod 属性 及 属性 值 
第 1 个 Label Text: 学 号 第 2 个 TextBox ID; tbxSnane 
第 2 个 Label Text: 姓名 第 3 个 TextBox ID; tbxSsex 
第 3 个 Label Text: 性 别 第 4 个 TextBox ID; tbxSage 
第 4 个 Label Text; 年 龄 第 5 个 TextBox ID: tbxSdept 
第 5 个 Label Text: 系 别 Button Text: 添加 
第 1 个 TextBox ID; tbxSno 


控件 属性 修改 后 ,设计 效果 如 图 5-40 所 示 。 


Defaukaspx x 


<formsforml>]| <div>]| «asp:ButtonsButtoni» 


图 540 设置 控件 属性 


第 4 步 ” 双 击 “ 添 加 ”按钮 ,进入 按钮 的 Click 事件 ,在 Click 所 在 的 文件 内 编写 代码 ,最 
终 代码 如 下 。 

注意 : Connection 在 使 用 之 前 ,一 定 要 打开 。 

using System; 

using System.Collections.Generic; 

using System. Ling; 

using System. Web; 

using System.Web.UI; 

using System. Web.UI .WebControls; 

using System. Data.SqlClient; 


Public partial class Default : System.Web.UI. Page 


{ 

protected void Page 1оай (Gbject sender, EventArgs e) 
t 

if (!this.IsPostBack) 

{ 

this.ShowStudent () ; 

} 

} 


protected void Buttonl Click(doject sender, EventArgs е) 
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string sno =this.tbxSno.Text; 

string sname =this .thxSname. Text; 

string зех —this.tbxSsex. Text; 

string sage =this .thxSage.Text; 

string sdept =this.thwxSdept..Text; 

string sql =" insert into student values ('" +sno +"','" tsname +", 
'" 455ex +"'," +sage +", '" абер 1211)"; 


string url -"Data Source =. ; Initial Catalog -studentTb; Integrated 
Searrity -True"; 

SqlConnecticn conn 2new SqlConnection (url) ; 

conn.Open () ; 


SqlCamand ard =new SqlCormand (sql, conn) ; 
arnd.ExecuteNorQuery () ; 

omn.Close() ; 

this.ShowStudent () ; 


private void ShowStudent () 
{ 
string url "ata Source =. ; Initial Catalog -studentTb; Integrated 
Security -True"; 
SqlConnecticn conn =new SqlConnection (url) ; 
conn.Open () ; 
SqlCamand ard -new SqlCamand ("select * fram Student", com); 
SqlDataReader reader =d. ExecuteReader () ; 


while (reader .Read () ) 

{ 
Response. Write (reader ["sno"]) ; 
Response. Write (","); 
Response. Write (reader ["sname"]) ; 
Response. Write (","); 
Response. Write (reader ["ssex"]) ; 
Response. Write (",") ; 
Response. Write (reader ["sage"]) ; 
Response.Write (",") ; 
Response. Write (reader ["sdept"]) ; 
Response. Write (" «br >"); 

) 

reader.Close(); 

сопп.С1озе(); 
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图 5-41 页 面 运行 效果 


第 6 步 在 输入 框 内 输入 信息 ,如 图 5-42 所 示 。 


201215121， 李 勇 ， 男 ， 
201215122, XJ, Ж. 
201215123, IB, ir, 18, 
201215125, Жз, 8, 19, 
(201215128 


张无忌 


图 5-42 页 面 录入 效果 


第 7 步 单 击 “ 添 加 ”按钮 ,输入 数据 被 添加 到 数据 库 ,并 从 数据 库 读 取 呈 现在 网 页 上 ， 
效果 如 图 5-43 所 示 。 

【拓展 提高 】 
1. 数据 库 连接 字符 串 保存 在 Web. config 中 
在 Web. config 中 配置 数据 源 连接 字符 串 : 
<connecticnStrings > 

<add папе -"studentTbConnecticnString" oonnectionString ="Data 

Source —.; Initial Catalog -studentTb; Integrated Security -True" 

providere -"System.Data .SglClient"/ > 
«/oonnectionStrings > 

149. 


四 localhost8909/chap5-2 x 
€ > С [localhost:8909/chap5-2/Default.aspx 
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图 543 ”添加 学 生 后 效果 


在 程序 中 获取 字符 串 : 

String url 

-Gonnection (ConfiguratiorMsnager .ConnectionStrings ["oonnStr"] .GonnecticnString; 
2. 调用 存储 过 程 

(1) 执行 不 带 参数 的 存储 过 程 : 


SqlConnecticn Conn =пем SqlConnection (url) ; 
Сопп.Ореп ( ; 

SqlCamand сті new Sql Cmand ("sp named", Com); 
crd.CommandType -CamandIype. StoredProoedure; 
SqlDataReader dr -amd.ExecuteReader () ; 


(2) 执行 带 普 通 参 数 的 存储 过 程 : 


SqlConnecticn Conn =пем SqlConnection (url) ; 
Сопп.Ореп (); 

SqlCamand сті new SqlCommand ("эр name2 ", Com); 
ard.CamandIype =Cormandlype.StoredProcedure; 
andi. Parameters .Acd ("@sno", Sql[bType.VarChar, 9); 
aui. Parameters ["@sno"] .Value ="201403031124"; 
SdlDataReader dr =amd.ExecutsReader () ; 


(3) 执行 带 output 型 参数 的 存储 过 程 : 


SallConnecticn Conn ew SqlConnecticn (url) ; 

Conn.Open () ; 

SqlCoamand ad new SqlCamand ("5р name3", Conn) ; 
armd.Camendlype -andlype.StoredProcedure; 

aud. Parameters. Act ("@Cant", SqlTEType. VarChar, 9); 

arm. Parameters ["@count"] .Di rection -ParameterDi rection. Output; 
SqlDataReader dr and. ExecuteBeacer () ; 
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四 、 项 目 小 结 


本 项 目 讲解 了 SQL 的 核心 知识 .SSMS 的 使 用 以 及 ADO. NET 的 主要 对 象 和 开发 过 程 ， 
本 内 容 属于 ASP . NET 数据 库 编 程 的 基础 ,是 现代 程序 开发 必 不 可 少 的 技术 。 


五 、 项 目 考核 


1. 填空 题 

(1) ADO. NET 有 两 个 核心 组 件 : . NET 数据 提供 者 和 o 

(2) ADO. NET 访问 数据 的 方式 有 两 种 ,其 中 一 种 是 通过 对 象 , 它 是 读 取 数 据 
的 最 简单 的 方式 ,只 能 进行 读 取 , 且 只 能 按 顺 序 从 头 到 尾 依次 读 取 数 据 。 

(3) SqlConnection 对 象 可 以 使 用 属性 来 获取 或 设置 打开 SQL 数据 库 的 连接 字 
符 串 。 

(4) 当 Command 对 象 用 于 存储 过 程 时 ,可 以 将 Command 对 象 的 CommandType 属性 数 
值 设置 为 o 


(5) DataAdapter 对 象 的 方法 用 于 使 用 DataAdapter 对 象 的 的 结果 填 
充 DataSet。 

(6) . NET FrameWork 数据 提供 程序 的 4 个 核心 对 象 是 
和 o 

2. 选择 


(1) 关于 DataReader 对 象 , 下 列 说 法 正确 的 是 ( ) 
A. 可 以 从 数据 源 随 机 读 取 数据 
B. 从 数据 源 读 取 的 数据 可 读 可 写 
С. 从 数据 源 读 取 只 前 进 且 只 读 的 数据 流 
D. 从 数据 源 读 取 可 往 前 也 可 往 后 且 只 读 的 数据 流 
(2) 如 果 要 将 DataSet 对 象 修改 的 数据 更 新 回 数据 源 ,应 使 用 DataAdapter 对 象 的 ( 
方法 。 


A. Fill B. Change C. Update D. Refresh 
(3) 在 DataSet 中 可 以 有 ( ) DataTable。 

А. 134 B. c. 多 个 D. 不 确定 
(4) ADO. NET 对 象 中 链接 数据 库 的 对 象 是 (。 ” ). 

A. Connection XJ% B. Command 对 象 

C. DataSet 对 象 D. DataReader XJ @ 


(5) ADO. NET 命名 空间 提供 了 多 个 数据 库 访 问 操作 的 类 ,其 中 (。 ”) 提 供 了 SQL 
Server 数据 库 设计 的 数据 存 取 类 。 
A. System. Data B. System. Data. SqlClient 
C. System. Data. Sql D. System. Web 


=» 


з. 简 答题 

(1) ASP .NET 中 访问 数据 主要 有 哪 几 种 方式 ? 

(2) 简要 说 明 适 用 DataReader 对 象 访问 数据 库 的 优 缺 点 。 
(3) 简 述 DataSet 对 象 的 功能 

(4) 简 述 ADO. NET 的 开发 步骤 。 

(5) 简 述 数据 查询 和 操纵 的 SQL 语法 。 

4. 上 机 操作 题 

(1) 在 SSMS 客户 端 中 ,练习 任务 5-1 中 的 SQL 语句 。 

(2) 使 用 DataReader 对 象 呈 现 课 程 信息 ,并 且 能 添加 课程 。 
(3) 使 用 DataSet 对 象 呈现 课程 信息 。 
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项 目 6 数据 控件 与 数据 绑 定 
‚Эч 


数据 绑 定 是 ASP .NET 的 特色 , 它 提 供 了 另外 一 种 数据 库 访 问 技 术 。 与 ADO. NET 相 比 
数据 绑 定 技术 的 优点 十 分 明显 : 程序 员 可 以 不 关注 数据 库 的 连接 .数据 库 的 命令 以 及 执行 
等 细节 ,直接 把 数据 源 绑 定 到 数据 控件 即 可 完成 工作 。 


二 、 项 目 要 点 


本 项 目 通过 4 个 任务 讲解 数据 源 控 件 ,数据 绑 定 控件 的 使 用 ,要 求 掌握 数据 源 控件 及 其 
配置 ;掌握 数据 绑 定 控件 的 常用 属性 .事件 和 配置 ;掌握 GridView 控件 的 使 用 ; 理解 
DetailsView „ListView .DataList 等 控件 的 使 用 。 

本 项 目 讲解 ASP . NET 中 数据 库 编 程 的 高 级 应 用 ,是 . NET 技术 特有 的 技术 ,也 是 
.NET 在 快速 开发 方面 的 优势 所 在 。 
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任务 6-1 使 用 SqlDataSource 控件 检索 数据 


【任务 描述 】 

小 王 在 开发 过 程 中 ,感觉 数据 库 的 读 取 十 分 麻烦 ,代码 重复 率 也 很 高 ,他 想 找 一 种 简单 
快捷 的 从 数据 库 读 取 数 据 的 方法 ,从 而 提高 开发 效率 。ASP . NET 提供 的 SqlDataSource 控 
件 正 好 满足 小 王 的 需要 。 


【任务 目的 】 

掌握 数据 源 控件 的 使 用 ,创建 和 配置 SqlDataSource 控件 。 
使 用 SqlDataSource 控件 从 数据 库 表 中 检索 满足 条 件 的 数据 。 
使 用 SqlDataSource 控件 从 数据 库 表 中 检索 结果 进行 排序 。 


【任务 分 析 】 

用 户 经 常 需要 从 数据 库 中 检索 信息 并 在 ASP . NET 网 页 中 显示 它们 ,为 此 ,需要 学 
ASP .NET 如 何 从 数据 库 中 检索 数据 。ASP . NET 提供 了 一 组 “数据 源 控件 ”的 Web еч 
专门 设计 用 于 访问 底层 数据 库 的 数据 。 使 用 数据 源 控件 检索 数据 库 数 据 非常 简单 ,只 需要 
拖 放 一 个 控件 到 ASP . NET 网 页 中 ,并 按照 向 导 提 示 制 定 要 获取 的 数据 库 数据 。 

SqlDataSource 控件 是 ASP . NET 提供 的 诸多 控件 之 一 ,SqlDataSource 控件 使 用 的 难度 
在 于 其 配置 ,其 必要 的 配置 为 两 项 ,一 是 连接 字符 串 , 二 是 SELECT 语句 。 
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【基础 知识 
1. 数据 源 控 件 


数据 源 控件 可 从 数据 源 中 检索 数据 ,可 以 用 于 绑 定 到 各 种 数据 绑 定 控件 。 数 据 源 控件 
大 大 减少 了 为 检索 和 绑 定 数据 甚至 对 数据 进行 排序 、 分 页 或 编辑 而 需要 编写 的 自 定 义 代码 


的 数量 和 工作 量 。 


在 ASP .NET 中 主要 有 7 种 数据 源 控件 ,每 个 数据 源 控件 的 名 称 都 以 DataSource 结尾 。 
每 个 数据 源 控件 设计 用 于 操作 不 同 数 据 源 , 即 进行 特定 类 型 的 数据 访问 。 表 6-1 描述 了 


ASP .NET 中 的 每 个 数据 源 控件 。 


表 6-1 ASP .NET 中 的 数据 源 控件 


数据 源 控件 名 称 说 
支持 访问 ADO. NET 数据 提供 的 所 有 数据 源 。 该 控件 默认 可 以 访问 ODBC, 
SUIDA OLEDB „SQL Server „Oracle 和 SQL Server CE 提供 的 数据 
AccessDataSource 可 以 对 Access 数据 库 执 行 特定 的 访问 
ObjectDataSource 可 以 对 业务 对 象 或 其 他 返回 数据 的 类 执行 特定 的 数据 访问 
LinqDataSource 可 以 使 用 LINQ 查询 不 同类 型 的 数据 
XmlDataSource 可 以 对 XML 文档 执行 特定 的 数据 访问 ,包括 物理 访问 和 内 存 访 问 
SiteMapDataSource 可 以 对 站 点 地 图 提供 程序 存储 的 Web 站 点 进行 特定 数据 访问 
EntityDataSource EntityDataSource 适合 和 实体 数据 模型 生成 器 一 起 来 生成 快速 开发 的 应 用 程序 


数据 源 控件 在 Visual Studio 的 工具 箱 的 “数据 ?部 
分 找到 ,如 图 6-1 所 示 。 

虽然 不 同 的 数据 源 控件 使 用 于 特定 的 数据 源 , 但 所 
有 的 数据 源 控件 共享 一 组 基本 的 核心 功能 ,因此 所 有 数 
据 源 控件 的 使 用 都 是 相同 的 。 使 用 ASP . NET 开发 时 ， 
最 常用 的 数据 源 为 Microsoft SQL Server 数据 库 系统 ,而 操 
作 Microsoft SQL Server 数据 库 的 数据 源 控件 为 
SqlDataSource ,因此 本 书 重点 讲解 SqlDataSource 控件 。 

注意 : 数据 源 控件 是 用 来 检索 数据 库 数 据 的 ,不 能 
在 网 页 中 显示 , 若 要 显示 数据 ,需要 使 用 其 他 控件 ,比如 
GridView , DataList 等 服务 器 控件 。 

2. SqlDataSource 控件 

SqlDataSource 控件 需要 访问 Microsoft SQL Server 数 
据 库 ,为 了 节省 时 间 ,可 直接 使 用 第 5 章 的 数据 库 。 

(1) 建立 SqlDataSource 控件 。 SqlDataSource 控件 
的 建立 十 分 简单 , 只 需 从 Visual Studio 工具 箱 中 把 
SqlDataSource 控件 拖 放 到 网 页 即 可 。 
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图 6-1 Visual Studio 中 的 数据 源 控件 


(2) 配置 SqlDataSource 控件 。SqlDataSource 控件 的 配置 过 程 步骤 较 多 ,但 可 以 分 为 两 
项 ,一 是 连接 字符 串 的 配置 ,主要 为 选择 数据 源 的 类 型 选择 数据 库 服务 器 、 选 择 数据 库 等 ; 
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二 是 配置 SELECT 语句 , 主要 为 选择 表 、 选 择 列 、 添 加 WHERE 条 件 、 设 置 排序 等 。 
SqlDataSource 控件 的 主要 属性 如 表 6-2 所 示 。 
36-2 SqlDataSource 控件 属性 
属性 名 称 说 — H 
ID 该 属性 唯一 地 表示 该 数据 源 控件 


人 该 属性 制定 用 于 连接 到 数据 库 的 连接 字符 串 ,通常 连接 字符 串 保存 在 Web 应 用 
is 程序 的 配置 文件 中 , 即 web. fonfig 中 


SelectCommand 该 属性 指定 向 数据 库 发 出 的 SELECT 查询 语句 


配置 好 的 SqlDataSource 控件 代码 如 下 : 
<asp:SqlDataSource ID "Sal DataScurosd" runat ="server" 
ConnecticnString-" <% $ ConnectionStrings:studentIEConnectionString $ >" 
SelectCcmmend-—"SEIECT * FROM [student]" > «/asp:SqlDataScurce > 

其 中 ConnectionString 的 值 为 <% $ ConnectionStrings : studentDbConnectionString 96 > ,此 处 意 
思 为 连接 字符 串 保 存在 web. config 文件 中 。 在 web. config 文件 中 可 以 找到 如 下 代码 ,此 代 
码 为 系统 自动 生成 。 

知识 链接 : SqlDataSource 控件 除了 SelectCommand 属性 外 ,还 可 以 有 InsertCommand , 
UpdateCommnand 和 DeleteCommand 属性 ,也 就 是 说 可 以 通过 SqlDataSource 查询 .插入 ,修改 
和 删除 数据 。 

<ccnnecticnStrings > 

«add name =" sturient[tConnecticnString" connecticnstring =" Data Source =. \SQIEXFRESS; Initial 
Catalog -studentTb; Integrated Security =True" 
providere "System. Data .SqlClient" /> 

</connectionStrings > 

【任务 实施 】 

第 1 步 ”新建 一 个 网 站 ,命名 为 : cha6_1 ,添加 一 个 名 称 为 defalut. aspx 的 ASP .NET 网 
页 ,再 从 工具 箱 中 拖 放 SqlDataSource 控件 到 网 页 中 。 

第 2 步 单 击 SqlDataSource 数据 源 控件 的 右边 的 “大 于 符号 ” , 单 击 “ 配 置 数据 源 ” 按 
钮 ,如 图 6-2 所 示 。 

第 3 步 单 击 下 拉 框 , 若 存 在 符合 条 件 连 
接 则 选中 ,否则 单 击 “ 新 建 连接 "按钮 ,如 图 6- 
3 BUR. 图 6-2 ”数据 源 控件 

第 4 步 ” 选中 Microsoft SQL Server 项 , 单 击 “确定 "按钮 ,如 图 6-4 所 示 。 

第 5 步 ”设置 服务 器 名 为 “. \sqlexpress”, 选 择 “ 使 用 Windows 身份 验证 ” ,选择 数据 库 
名 为 studentDb ,如 图 6-5 所 示 ,然后 单 击 “ 确 定 " 按 钮 。 

第 6 步 ， 单 击 连 接 字符 串 前 的 + "号 ,查看 链接 字符 串 , 单 击 “ 下 一 步 "按钮 ,如 图 6-6 
所 示 。 
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图 6-3 ”选择 连接 
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[ni erosoft SQL Server slClient) 


mo] 
wm ) 


LIE LI 


数据 源 8); 

Microsoft Access 数据 库 文 件 TR z 

Microsoft ODBC 使 用 此 选择 ， 可 以 通过 用 于 SQL 
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图 64 ”选择 数据 源 图 6-5 添加 链接 
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图 66 连接 字符 串 
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小 提示 : 第 一 次 配置 数据 源 控件 时 ,需要 “新 建 连接 " ,以 后 就 可 以 直接 选择 连接 , 单 击 
“新 建 连接 "前 的 下 拉 框 ,就 可 以 看 到 以 前 创建 的 连接 。 
第 7 步 单 击 “下 一 步 "按钮 ,保存 连接 到 配置 文件 ,如 图 6-7 所 示 。 


tudeatDJMConnectienString 


图 6-7 连接 字符 串 保存 
第 8 步 ” 指 定 表 的 名 称 为 student, 选 中 所 有 列 , 单 击 “ 下 一 步 " 按 钮 ,如 图 6-8 所 示 。 


图 6-8 配置 SELECT 语句 


第 9 步 单 击 * 测 试 查询 ” ,查看 数据 ,如 图 6-9 所 示 。 


【任务 小 结 】 

本 任务 介绍 了 DataSource 数据 源 控件 ,重点 介绍 了 SqlDataSource 控件 的 创建 和 配置 。 
SqlDataSource 数据 源 控件 设计 用 于 从 数据 库 检 索 数据 。SqlDataSource 需要 两 项 信息 才能 从 
数据 库 中 检索 数据 : 连接 到 数据 库 的 信息 和 要 执行 的 SQL 查询 语句 。 
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SELECT * FROM [student] 


[ce ) т 
图 6-9 数据 源 测试 数据 


【拓展 提高 】 

l. 筛选 数据 

第 1 步 在 配置 SELECT 语句 的 基础 上 ,如 图 6-8 所 示 , 单 击 WHERE 按钮 ,弹出 添加 筛 
选 条 件 对 话 框 ,如 图 6-10 所 示 。 
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图 6-10 ”添加 筛选 条 件 
第 2 步 ” 列 选中 sage, 运 算 符 选中 “<”, 源 选中 None , 值 填写 为 20 ,然后 单 击 “ 添 加 ” 按 
钮 ,添加 筛选 条 件 对 话 框 界面 变 为 图 6-11 所 示 效 果 , 单 击 * 确 定 "按钮 。 
小 提示 : 此 处 较 难 ,请 认真 理解 和 操作 。 


第 3 步 在 “测试 查询 "对 话 框 中 单 击 “ 测 试 查询 ” ,弹出 “参数 值 编辑 器 " 对话 框 ,如 
图 6-12 所 示 。 


第 4 步 ， 单 击 “ 确 定 "按钮 ,出现 测试 结果 ,如 图 6-13 所 示 。 
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quus EE 子 句 中 添加 一 个 或 多 个 条 件 。 可 以 为 每 个 条 件 指定 文 本 值 或 参数 化 的 值 。 参 数 化 的 值 在 运行 时 根据 其 属性 获 职 


图 6-11 筛选 条 件 结果 


Бан 
为 Select 语句 中 定义 的 每 个 参数 指定 类 型 和 值 。 


参数 类 型 


图 6-12 参数 值 编辑 器 


配置 数据 源 - SalDataSourcel 


| 测试 查询 
L 
SEBUUDUMESE ERR , аф "WU". EXGTHAS, WA “ЖЫ”. 


mno sneme sser sage sdept 


SELECT 语句 Q): 
SELECT * FROM [student] WHERE ([sage] < @sage) 


图 6-13 ”测试 查询 结果 
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2. 数据 排序 


第 1 步 在 配置 SELECT 语句 对 话 框 上 ,如 图 6-8 所 示 , 单 击 “ 排 序 ” 按 钮 ,弹出 “ 


Order by 子 句 ”对话 框 ,如 图 6-14 所 示 。 排 序 方式 中 排序 列 选择 为 sage ,升序 。 


添加 ORDER BY 子 句 


指定 要 作为 排序 依据 的 列 。 
排序 方式 


SELECT 语句 QL) 
SELECT ж FROM [student] WHERE ([sage] < @sage) ORDER BY [sage] 


图 6-14 添加 排序 


第 2 步 ”测试 查询 ,结果 如 图 6-15 所 示 。 
i£. == 
SEBXUDESERUDRE, жаз "MEUM. таянат, ев "ЖЫ". 


[Kipi 


[SELECT * FROM [student] ORDER BT [sage] 


图 6-15 “排序 测试 查询 结果 


3. 生成 INSERT „UPDATE „DELETE 语句 


第 1 步 在 配置 SELECT 语句 对 话 框 上 ,如 图 6-8 Bron , 单 击 “高 级 "按钮 , 弹 贞 


SQL 生成 选项 "对 话 框 , 如 图 6-16 所 示 。 


第 2 步 选中 "生成 INSERT UPDATE , DELETE 语句 "选项 , 单 击 “确定 "按钮 。 


4. 查看 SqlDataSource 控件 的 HTML 标记 


添加 


“高 级 


经 过 以 上 SqlDataSource 控件 的 配置 ,包括 配置 连接 字符 串 .SELECT 语句 以 及 WHERE 
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可 以 生成 附加 的 INSERT. UPDATE 和 DELETE 语句 来 更 新 数据 源 ， 


EER INSERT, WPBATE 和 DELETE 语句 (6) 
[和 


O 使 用 开放 式 并 发 O 


КЁ дид. шип жошнде! aaa sukama aE 
Cj 


图 6-16 高 级 SQL 生成 选项 


条 件 和 排序 INSERT UPDATE , DELETE 语句 ,生成 的 HTML 代码 如 下 。 


«asp:SqlDataScurce ID -"SqlDataScurcel" runat -"server" 
GonnecticnString =" < $  ConnectionStrings:studentIbConnectionString $ >" 
DeleteCormand -"TEIETE FRM [student] WHERE [sno] -8sno" 
InsertCammand "NÆRT INIO [student] ([sno], [sname], [ssex], [sage], 
[sdept]) VALUES (8sno, @ѕпапе, @ѕзех, Gsage, Gsdept)" 
SelectCuamend -"SEIECT * FRM [student] WHERE ([sage] &lt; Gsage) CHER BY [sage]" 
UPadateComand "UPATE [student] SET [sname] @snane, [ssex] =@ззех, [sage] = 
Gsage, [sdept] -Gsdept WHERE [sno] =@sno" > 
XDeleteParareters > 
«asp:Parameter Name -"sno" Type -"String" /> 
«/DeleteParameters > 
XInsertParameters > 
«asp:Parameter Name -"sno" Type -"String" /> 
«asp:Parameter Name ="зпате" Type -"String" / > 
«asp:Parameter Name -"ssex" Type -"String" / > 
«asp:Parameter Name "sage" Type -"Int32" /> 
«asp:Parameter Nare ="sdept" Туре -"String" /> 
«/InsertParameters > 
«SelectParameters > 
«asp:Parameter DefaultValue ="20" Мате ="sage" Type -"Int32" /> 
«/SelectParameters > 
«UpdateParameters > 
<азр:Рагапеќег Мате ="зпате" Type -"String" /> 
«asp:Parameter Мапе ="ssex" Type "String" /> 
«asp:Parameter Name -"sage" Type -"Int32" /> 
<азр:Рагапеќег Мате ="sdept" Type -"String" /> 
«asp:Parameter Мапе ="sno" Type -"String" /> 
«/üpdateParameters > 
«/asp:SglDataSource > 


任务 6-2 ”实现 学 生 下 拉 框 绑 定数 据 


【任务 描述 】 
小 王 发 现 下 拉 框 内 容 固定 ,在 系统 运行 过 程 中 ,需要 时 常 维护 ,费时 费力 ,他 在 想 能 不 能 
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程 中 ,如 果 有 改变 , 则 可 以 通过 维护 数据 库 内 的 数据 来 维护 系统 。 


【任务 目的 】 
掌握 数据 源 控件 的 使 用 ,创建 和 配置 SqlDataSource 控件 。 


【任务 分 析 】 
SqlDataSource 控件 是 ASP . NET 提供 众多 控件 之 一 ,SqlDataSource 控件 使 用 的 难度 在 
于 其 配置 ,其 必要 的 配置 为 两 项 ,一 是 连接 字符 串 , 二 是 SELECT 语句 。 


【基础 知识 】 

1. 数据 绑 定 

在 ASP .NET 中 ,引入 了 数据 绑 定语 法 ,使 用 该 语法 可 以 轻松 将 Web 控件 的 属性 绑 定 到 
数据 源 ,语法 为 : 

<%#ataSouroes > 


这 里 的 DataSource 表示 各 种 数据 源 ,可 以 是 变量 表达 式 、 属 性 列表 数据 集 、 视 图 等 。 

在 指定 了 绑 定数 据 源 后 ,通过 调用 控件 的 DataBind ( ) 方 法 或 者 该 控件 所 属 父 控件 的 
DataBind( ) 方 法 来 实现 页 面 的 所 有 控件 的 数据 绑 定 , 从 而 在 页 面 中 显示 出 相应 的 绑 定数 据 。 
DataBind( ) 方 法 是 ASP .NET 的 Page 对 象 和 所 有 Web 控件 的 成 员 方法 由 于 Page 对 象 是 该 
网 页 中 所 有 控件 的 父 控件 ,所 以 在 该 页 面 中 调用 DataBind( ) 方 法 将 会 使 页 面 中 的 所 有 数据 
绑 定 被 处 理 。 通 常情 况 下 ,Page 对 象 的 DataBind( ) 方 法 在 Page. Load 事件 响应 函数 中 调用 : 


protected void Page Ioed(doject sender, EventArgs e) 
{ 


Page.DataBind (); 
} 

2. Жета 

数据 绑 定 到 变量 的 语法 格式 为 

性 简单 变量 名 称 $ > 
其 中 ,变量 名 称 必须 是 可 用 的 变量 。 如 果 变 量 的 声明 在 后 台 代 码 , 要 将 其 设 为 public 或 
protected 类 型 ,否则 将 出 现 变量 受 保护 级 别 限制 的 错误 。 

3. WERA 

数据 绑 定 到 集合 的 语法 格式 为 

edifici 
绑 定 集合 的 情况 主要 用 于 一 些 多 记录 服务 器 控件 ,比如 DropDownList 控件 、ListBox 控件 和 
GridView 等 。 

4. 绑 定 表达 式 

数据 绑 定 到 表达 式 的 语法 为 

SIRERE > 
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在 许多 管理 信息 系统 中 ,经 常 需 要 显示 一 些 计 算得 出 的 数据 ,对 于 这 些 数据 ,可 以 利用 表 
达 式 做 一 些 简单 处 理 , 然 后 将 表达 式 的 执行 结果 绑 定 到 控件 的 属性 上 ,将 这 些 数据 显示 出 来 。 

5. 绑 定 方法 

数据 绑 定 到 方法 返回 值 的 语法 格式 为 

«ik 参数 列表 )%> 


对 于 复杂 的 计算 ,需要 对 数据 进行 比较 复杂 的 操作 计算 ,必须 利用 方法 对 其 进行 处 理 ， 
然后 把 方法 的 返回 值 绑 定 到 显示 控件 的 属性 。 

6. 控件 绑 定数 据 

数据 绑 定 控件 可 以 是 单 值 控件 ,也 可 以 是 多 记录 控件 ,其 中 单 值 控件 使 用 数据 绑 定 较 
少 ,主要 是 多 记录 的 服务 器 控件 使 用 数据 绑 定 ,该 类 控件 主要 包括 DropDownList, ListBox, 
GridView , DataList , FormView , Repeater 等 控件 。 

该 类 控件 在 绑 定 时 ,可 以 直接 把 数据 绑 定 到 显示 控件 的 属性 ,也 可 以 使 用 C# 语 句 动态 
绑 定 。 

知识 链接 : 在 实际 项 目 中 ,为 了 系统 灵活 性 和 维护 方便 ,很 多 数据 都 是 来 自 于 数据 库 ， 
而 不 是 写 到 代码 中 ,而 ASP. NET 可 以 直接 把 数据 库 的 数据 绑 定 到 页 面 上 ,提供 了 很 大 的 
Ad. 

【任务 实施 】 

第 1 步 创建 项 目 chap6-2 ,新 建 Web 窗 体 default. aspx. 

第 2 步 TE default. aspx 的 设计 视图 中 , 放 入 一 个 SqlDataSource 控件 ,对 SqlDataSource 
控件 进行 设置 ,设置 过 程 与 项 目 6 的 任务 6-1 相同 ,如 图 6-17 所 示 。 


Таз 


| SqlDataSource - SqlDataSourcel 


图 6-17 ЖА SqlDataSource 界面 


第 3 步 ” 在 设计 窗口 输入 “学 生 .“" 字 样 ,在 其 后 拖 和 人 一 个 DropDownList 控件 ,效果 如 
图 6-18 所 示 。 


| SqlDataSource - SqlDataSourcel 


96-18 ЖЛ FREA 
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第 4 步 单 击 “下 拉 框 控件 "右边 的 ” > "符号 ,打开 下 拉 框 控件 的 设置 窗口 ,如 图 6-19 
所 示 。 


Default2.aspx web.config ЖАУ Mill Deíautaspx x 


SqlDa! - 
asp:DropDownList&DropDovnListi) 
学 生 ; [ARRE `= |<] Droppownist 任务 


启用 AutoPostBack | 


< 


awt | 口 拆 分 | 回 源 [@[<Ьоду>][<югтеогт1»][<@м>] <asp:DropDownList#DropDow..>| 四 
图 6-19 打开 DropDownList 任务 界面 


第 5 步 单 击 图 6-19 弹出 窗口 的 “选择 数据 源 " ,打开 设置 数据 源 向 导 , 如 图 6-20 
所 示 。 


rc mmus w 
ая MaponBeck = 


图 6-20 下拉 框 绑 定数 据 界 面 


选择 数据 源 为 SqlSataSourcel ,这 是 刚才 创建 的 数据 源 , 在 “选择 要 在 DropDownList 中 显 
示 的 数据 字段 "下 边 的 输入 框 中 输入 sname, 在 “为 DropDownList 的 值 选择 数据 字段 "下 边 的 
输入 框 中 输入 sno。 如 图 6-21 所 示 。 

小 提示 : 选择 数据 源 后 ,一 定 要 填写 显示 数据 字段 和 值 选择 数据 字段 ,并 且 要 和 数据 库 
中 表 字 段 一 致 。 

第 6 步 单 击 “ 确 定 "按钮 ,数据 源 设置 成 功 ,关闭 “数据 源 配 置 向 导 " 窗 口 ,在 Default 
. aspx 网 页 的 设计 视图 的 下 拉 框 中 ,内 容 由 原来 的 “未 绑 定 " 变 为 “数据 绑 定 ", 如 图 6-22 
所 示 。 

第 7 步 ”开发 完成 , 单 击 调试 ,效果 如 图 6-23 所 示 。 
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为 DropDownList 的 值 选择 至 据闻 段 (C: 


sno - 


6-21 绑 定 数据 绑 定 


LI = а к wa 
SqlDataSource - SqlDataSource1 ] 
mer. ГЕ 2] | 


图 6-22” 绑 定数 据 后 界面 


D localhost:40484/chap6- х 
Sub. [n localhost:40484/chap6-2/Default.aspx 
EE, [тю] 


E623 运行 效果 


第 8 步 单 击 网 页 中 的 下 拉 框 ,打开 下 拉 框 ,效果 如 图 6-24 所 示 。 

【任务 小 结 】 

本 任务 介绍 了 常用 的 数据 绑 定 技术 ,重点 介绍 了 把 数据 源 控件 和 DataSet 对 象 绑 定 到 
DropDownList 控件 。 数 据 绑 定 技术 功能 强大 、 使 用 简单 并 且 灵 活 ,是 使 用 ASP . NET 技术 进 


行 开发 中 不 可 或 缺 的 技术 之 一 。 
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Ë 到 m s gu К 
еэ с ГУУЗ -2/Default.aspx 


HE. (шат 
78 
rü 
张 立 


图 6-24 下 拉 框 效果 


【拓展 提高 】 

DropdownList 绑 定 Dataset 的 步骤 如 下 : 

第 1 步 在 网 站 chap6-2 中 ,新 建 一 个 Web 窗口 ,命名 为 "Default aspx” o 

第 2 步 YE Web 窗口 的 Default. aspx 设计 视图 中 放 入 一 个 DripDownList 控件 ,如 
图 6-25 所 示 。 


ка| ean 
= àMK$—IIHÉIEIIW@PKII€IZeEIEISIO@€ITIIOI0IICMGCOOZISIS ; 同 解决 方案 “chap6-2”(!1 个 项 目 ) 
= Wi: 4 @ dAnetwork\chap6-2\ 
b [E] Defaultaspx 
4 国 Default2.aspx 
| 加 Default2.aspx.cs 
E web.config 


бе] 


图 6-25 设计 界面 图 626 打开 Default2. aspx. cs 源 文件 


第 3 步 。 单 击 打开 Default. aspx. cs 文件 ,打开 方式 如 图 6-26 所 示 ; 文 件 打 开 效 果 如 
图 6-27 所 示 。 


第 4 步 在 文件 内 容 上 边 的 using 下 边 添加 两 行 代码 : 


using System.Data; 
using System.Data.SqlClient; 


在 


protected void Page Iced(doject sender, EventArgs e) 
{ 
) 


中 添加 代码 如 下 : 


string connectionString ="Data Source =.; Initial Catalog =studentIb; 
Integrated Security =True"; 
SqlConnection conn new SqlOonnecticn (oonnectionString) ; 
SqlCamand amd -new SqlCamand ("select * from student", com); 
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со chap6-2 (正在 运行) - Microsoft Visual Studio (EEA) klak) 
XHA SAE МЕМ EAR 网 站 (S) ERB) 调式 (D) MUM) SEA IAM 体系 结构 (CO ВЫ) 


日 using System: 
using System.Collections.Generic: 
using System.Linq: 
using Systen. Veb: 
using System. Web. UI; 
[using Systen. Web. UI. VebControls; 


Epublic partial class Default? : System. Web. UI. Page 


日 protected void Page Load(object sender, Eventárgs e) 


图 6-27  Default2. aspx. cs 文件 打开 时 代码 


DataSet ds =пем DataSet () ; 

SqlDatahdapter sda -new Sci Dataacapter (ard) ; 

sda.Fi11 (ds, "student") ; 

this.DrapDownListl .DataTextField ="зпате"; 
this.DrapDownListl .DataValueField "sno"; 
this.DropDownListl.DataScurce -ds. Tables [0] .DefaultView; 
this.DragDownListl .DataBind (); 


效果 如 图 6-28 所 示 。 


i$ Default2 ~| 49 Page Load(object sender, EventArgs e) 


using System. Web; 

using System. Web. UI; 

using System. Web. UI. VebControls: 
using System.Data; 

using System. Data. SqlClient: 


Ejpublic partial class Default? : System. Veb. UI. Page 


protected void Page Load(object sender, Eventárgs e) 
t 
string connectionString = "Data Source-. ;Initial Catalog-studentDb;Integrated Security-True"; 

Connection conn = new SqlConnection(connectionString): 
ommand cmd = new SqlCommand( "select * from student", conn): 

t ds = new DataSet () : 
SqlDatahdapter sda = new SqlDataAdapter (cmd); 
sda. Fill (ds, “student”) ; 
this. DropDownList1. DataTextField = “пале”; 
this.DropDownListl.DataValueField = “по”; 
this.DropDownListi.DataSource = ds. Tables [0]. Default View: 
this. DropDownList 1. DataBind() : 


图 6-28 编写 代码 后 的 Default2. aspx. 


文件 
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第 5 步 ” 启 动 调试 ,运行 效果 与 图 6-23 .图 6-24 相同 。 
任务 6-3 使 用 GridView 实现 学 生 的 增删 改 查 


【任务 描述 】 

小 王 在 做 项 目 过 程 中 ,有 这 样 一 个 需求 ,需要 把 学 生 以 班级 的 形式 的 信息 在 网 页 上 显示 
出 来 ,并 能 在 网 页 上 对 其 修改 ,甚至 是 删除 ,这 种 综合 性 的 管理 涉及 内 容 很 多 ,小 王 很 是 

【任务 目的 】 

(1) 掌握 GridView 绑 定数 据 源 实 现 数据 展示 和 数据 的 修改 .删除 功能 的 方法 和 技术 。 

(2) 掌握 GridView 展示 数据 的 分 页 和 排序 效果 的 实现 。 

【任务 分 析 】 

数据 保存 在 数据 库 中 ,现在 要 把 数据 库 中 的 数据 展示 到 网 页 上 ,因此 需要 取出 数据 ， 
ASP .NET 提供 了 数据 源 控件 ,可 以 方便 地 取出 数据 ,数据 展示 到 网 页 是 一 个 表格 ,表格 的 
处 理 比较 麻烦 ,因此 ASP . NET 封装 表格 为 GridView, 可 以 快速 方便 地 实现 数据 的 显示 ,并 
且 还 提供 了 分 页 .排序 等 功能 。 另 外 GridView 控件 结合 SqlDataSource 控件 还 能 实现 数据 的 
添加 、 删 除 和 修改 功能 。 


【基础 知识 】 

1. GridView 控件 概述 

小 提示 : GridView 是 开发 过 程 中 使 用 最 为 频繁 的 控件 之 一 。 

GridView 是 一 个 功能 强大 的 数据 绑 定 控件 ,主要 用 于 以 表格 的 形式 呈现 编辑 数据 。 对 
应 于 关系 数据 集结 构 , Grid View 控件 以 列 为 单位 组 织 其 所 呈现 的 数据 ,GridView 不 但 能 使 普 
通 文本 ,还 能 使 按钮 .图片 复 选 框 等 控件 ,同时 支持 对 属性 设置 获得 自己 想 要 的 效果 。 

2. GridView 常用 属性 

GridView 的 常用 属性 如 表 6-3 所 示 。 


表 6-3 GridView 的 常用 属性 


# Ж 说 明 
Columns 获取 GridView 控件 中 列 字段 的 DataControlField 对 象 的 集合 
Contorls 获取 GirdView 控件 中 的 子 控件 的 集合 


DataKeyNames 获取 或 设置 显示 在 GridView 控件 中 的 项 的 主键 字段 名 称 
获取 和 设置 GridView 控件 的 数据 源 。 这 是 动态 数据 绑 定 的 一 个 重要 属性 。 该 属性 可 


Сазе 以 绑 定 DataTable , DataView 等 数据 对 象 
EditIndex 获取 或 设置 要 编辑 的 行 的 索引 
PageSize 获取 或 设置 Grid View 控件 在 每 页 上 所 显示 的 记录 数 


SelectedIndex 获取 或 设置 GridView 控件 中 的 选中 行 的 索引 
SelectedRow 获取 控件 中 的 选中 行 
AllowPaging 获取 或 设置 一 个 值 , 该 值 指 示 是 否 启用 分 页 功能 
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3. GridView 常用 方法 
GridView 的 常用 方法 如 表 6-4 所 示 。 


X64 GridView 的 常用 方法 


4. GridView 常用 事件 
GridView 的 常用 事件 如 表 6-5 所 示 。 


# Ж 说 明 

a 从 数据 源 绑 定 到 GridView 控件 。 设 置 DataSouree 属性 之 后 ,必须 通过 该 方法 才能 实 
现 数据 绑 定 

DeleteRow | 从 数据 源 中 删除 位 于 指定 索引 的 记录 

Sort 根据 指定 的 排序 表达 式 和 方向 对 GridView 控件 进行 排序 

UpadeRow — | 使 用 行 的 字段 值 更 新 位 于 指定 索引 位 置 的 记录 


表 6-5 GridView 的 常用 事件 


名 Ж 说 — HJ 
PagelndexChanged 在 单 击 某 一 行 导 航 按钮 时 ,在 GridView 控件 处 理 分 页 操作 之 后 发 生 
PageIndexChanging 在 单 击 某 一 行 导航 按钮 时 ,在 GridView 控件 处 理 分 页 操作 之 前 发 生 
RowCancelingEdit 单 击 编辑 模式 某 一 行 的 “取消 ”按钮 以 后 ,在 该 行 退出 编辑 模式 之 前 发 生 
RowCommand 当 单 击 GridView 控件 中 的 按钮 时 发 生 
RowDeleted 在 单 击 某 一 行 的 “删除 ”按钮 时 ,在 GridView 控件 删除 该 行 之 后 发 生 
RowDeleting 在 单 击 某 一 行 的 “删除 ”按钮 时 ,在 GridView 控件 删除 该 行 之 前 发 生 
RowEditing 在 单 击 某 一 行 的 “编辑 "按钮 之 后 ,GridView 控件 进入 编辑 模式 之 前 发 生 
RowUpdated 在 单 击 某 一 行 的 “更 新 "按钮 ,并 且 GridView 控件 对 该 行进 行 更 新 之 后 发 生 
RowUpdating 在 单 击 某 一 行 的 “更 新 "按钮 ,并 且 GridView 控件 对 该 行进 行 更 新 之 前 发 生 
A sod RI M “选择 "按钮 以 后 ,GridView 控件 对 相应 的 选择 操作 进行 处 理 
брейк бен i0 “选择 "按钮 以 后 ,GridView 控件 对 相应 的 选择 操作 进行 处 理 


5. GridView 控件 的 列 


GridView 控件 的 列 如 表 6-6 所 示 。 


表 6-6 GridView 控件 的 列 


名 Ж 说 明 
BoundField 以 文字 形式 呈现 数据 的 普通 绑 定 列 类 型 
CheckBoxField 以 复 选 框 形式 呈现 数据 , 绑 定 到 该 类 型 的 列 数据 应 该 具有 布尔 值 
以 链接 形式 呈现 数据 , 绑 定 到 该 类 型 的 列 数据 应 该 是 指向 某 个 网 站 或 网 上 资源 


HyperLinkField 


的 地 点 
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名 Ж 说 ш 
ImageField 以 图 片 形式 呈现 数据 
ButtonField 按钮 列 ,以 按钮 的 形式 呈现 数据 或 进行 数据 的 操作 。 例 如 删除 记录 的 按钮 列 
CommandField 系统 内 置 的 一 些 操作 按钮 列 ,可 以 实现 对 记录 的 编辑 修改 .删除 等 操作 
TemplateField 模板 列 绑 定 到 自 定义 的 显示 项 模板 ,因而 可 以 实现 自 定 义 列 样式 


知识 链接 : GridView 功能 强大 ,使 用 灵活 ,在 应 用 程序 中 使 用 频繁 。GridView 的 数据 可 以 
来 自 SqlDataSource 控件 ,也 可 以 来 自 DataSet, 还 可 以 来 自 集合 接口 ,如 List 等 。 


【任务 实施 】 
第 1 步 新 建 网 站 chap6-4 ,新建 Web 窗口 ,命名 为 Default. aspx; 
第 2 步 Web 窗口 Default. aspx 切换 到 “设计 ”视图 , 拖 和 人 一 个 SqlDataSource 控件 和 一 
个 Gridview 控件 ,效果 如 图 6-29 所 示 。 配 置 数据 源 控件 过 程 同 本 项 目 任务 6-1。 
йу i 


| SqlDataSource - SqlDataSourcel 
| 


图 629 放 入 数据 源 和 Grid View 控件 的 设计 界面 
第 3 步 "ul; GridView 控件 右上 角 的 “ > "符号 ,弹出 “GridView 任务 "窗口 ,如 图 6-30 所 示 。 


Й Defaultaspx х 


- SalDataSourcel 
asp:GridvieweGi 


sno sname ssex sage sdept 
abclabc abc 0 јас = А 
арс афс abc 1 abc — 

abc abc abc 2 ас ЖИИ 设置 控件 格式 设置 尾 性 | _ |] 
abclabc abc 3 јас EBSER. 

abcabc ас 4 abc Баню 


SEP.. 


添加 新 列 … 
зка |аш| [15 aman 
D 启用 排序 

Г] 启用 选 定 内 容 
| жшк 


图 6-30 GridView 任务 界面 
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第 4 步 在 “GridView 任务 "窗口 中 ,选择 数据 源 为 SqlDataSourcel , 则 GridView 效果 发 
生变 化 ,如 图 6-31 所 示 。 


sname ssex 


图 6-31 配置 了 数据 源 的 GridView 
第 5 步 ” 启动 调试 ,页 面 效 果 如 图 6-32 所 示 。 


E lele] x 
A) x Wa 
| £ > C |D localhost:12532/chap6-3/Default.aspx 2 三 
sno [sname] 
201215121 EB 
201215122590] & 
[201215123 Bt 


201215125| 张 立 


图 6-32 ”运行 效果 


第 6 步 停止 调试 ,打开 * GridView 任务 " , 单 击 * 编 辑 列 ” ,打开 GridView 的 字段 设置 页 
面 ,效果 如 图 6-33 所 示 。 


[a arde aan- Te : cmn w чазаа: | 
[текис езж шз [жэ тш А i DM. 


图 6-33 ”编辑 列 


第 7 步 在 “字段 "窗口 ,取消 左下 角 的 “自动 生成 字段 " ;选中 左下 方 的 sno 字段 ,打开 
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sno 的 BoundField 属性 ,效果 如 图 6-34 所 示 。 


[56-34  BoundField 属性 


第 8 步 TE sno 的 BoundField 属性 窗口 中 ,修改 sno 字段 的 HeaderText 属性 ,其 值 设置 
为 “学 号 ” ,如 图 6-35 所 示 。 


эю [e[ x] 


Gms) в...) 


图 6-35 编辑 学 号 列 


第 9 步 ” 仿照 修改 sno 的 HeaderText 属性 的 过 程 ,修改 sname , ssex , sage 和 sdept 的 
HeaderText 值 为 “姓名 ” “性别”“ 年 龄 "和 “ 系 别 ” ,效果 如 图 6-36 所 示 。 

第 10 步 ”启动 调试 ,打开 网 页 ,效果 如 图 6-37 所 示 。 

第 11 步 停止 调 试 ,打开 “GridView 任务 "窗口 , 单 击 “ 编 辑 列 " ,打开 “字段 "窗口 ,在 
“字段 "窗口 ,添加 可 用 字段 “CommandField" 下 的 “编辑 .更 新 取消 "“ 选 择 " 和 “删除 "字段 。 
效果 如 图 6-38 所 示 。 
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TAFRA: 


Б DynamicField 
[B sno 


拘 此 广 铺 转 接 为 TemplateField 


Cm (аж) 


图 6-36 编辑 学 生 表 的 其 他 列 


m XD XDXDX 


ТОЕ С (D) < NS 


€ > Q |D localhost:12532/chap6-3/Default.aspx 


学 号 “| 姓名 | 性 别 


201215121| 李 勇 


2012151221 


201215123 E Bi Ж 


201215125 |Ksz |8 


图 6-38 ”添加 命令 列 


173 


第 12 步 SqlDataSource 控件 重新 配置 。 打 开 配 置 数据 源 的 配置 Select 语句 窗口 ,如 
图 6-39 所 示 。 


SELECT #900: 
SELECT * FROM [student] 


图 6-39 ”数据 源 重新 配置 


第 13 步 单 击 “ 高 级 "按钮 ,打开 “高 级 SQL 生成 选项 " ,如 图 6-40 所 示 。 窗 口中 的 两 
个 选项 都 不 能 选择 ,这 是 因为 Student 没有 设置 主键 造成 的 。 
Fr | 
| 


| 可 以 生成 附加 的 INSERT. UPDATE 和 DELETE 语句 来 更 新 数据 源 . 


生成 INSERT、UPDATE 和 DELETE 语句 (G) 
基于 SELECT 语句 生成 INSERT. UPDATE 和 DELETE 语句 。 必 须 选 定 所 有 主键 字 
段 才能 启用 此 选项 。 


使 用 开放 式 并 发 (D) 


修改 UPDATE 和 DELETE 语句 以 检测 自 该 记录 加 载 到 DataSet 中 以 来 数据 库 是 否 更 
改 。 这 有 助 于 防止 并 发 冲 奕 。 


[ == jJ 
图 640 高 级 SQL 生成 


第 14 步 打开 数据 库 的 客户 端 ,修改 表 Student 的 定义 ,如 图 6-41 所 示 , 设 置 sno 为 
主键 。 


第 15 步 ” 保 存 表 Student 的 修改 时 ,出 现 错误 ,数据 库 不 允许 保存 修改 ,效果 如 图 6-42 
所 示 。 


第 16 步 ”选择 “工具 ”1“ 选 项 "菜单 命令 ,打开 “选项 ”对 话 框 ,取消 “阻止 保存 要 求 重 
新 创建 表 的 更 改 " 选 项 ,如 图 6-43 所 示 。 
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W| sno verchar(20) m 
sname varchar(50) 
ssex varchar(2) 

_ sage int m 
sdept varchar(100) 

m 


图 641 修改 Student Ж 


ea) явхахна ] 


图 6-42 ”拒绝 修改 


甲 环境 EX 
peua 同 EHEER EO): 
ке 
SQL Server 对 象 资源 管理 器 超过 此 对 间 后 事务 超时 (R): 
sanam 30 е 
| авнаа 
图 - 源 代 码 管理 加 生动 生成 更 改 涛 本 (A) 


图 6-43 ”修改 工具 选项 
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第 17 步 ” 回 到 数据 源 配置 界面 ,重新 配置 数据 源 , 单 击 “ 高 级 "按钮 ,弹出 图 6-44 所 示 
对 话 框 ,选中 “生成 INSERT UPDDATE 和 DELETE 语句 ”,“ 使 用 开放 式 并 发 "选项 可 选 可 不 
选 ,如 图 6-44 所 示 。 
ж до AEN, [ET 


М ”可 以 生成 附 hn 的 INSERT. UPDATE 和 DELETE 语句 来 更 新 数据 源 。 


[V] 生成 INSERT. UPDATE 和 DELETE 语句 (G) 
基于 SELECT 语句 生成 INSERT, UPDATE 和 DELETE 语句 。 必 须 选 定 所 有 主键 字 
段 才能 启用 此 选项 . 


使 用 开放 式 并 发 (D) 中 
修改 UPDATE 和 DELETE 语句 以 检测 自 该 记录 加 载 到 DataSet 中 以 来 数据 库 是 否 更 
改 。 这 有 助 于 防止 并 发 冲突 . 


Cw )[ w | 
图 644 高 级 SQL 生成 


第 18 步 启动 调试 ,打开 网 页 ,网 页 中 多 出 了 “编辑 "”“ 选 择 ”" 和 “删除 ”3 列 ,如 图 6-45 
所 示 。 


FG sgp СЕЗ 
20126121! Ë 
201215122 30 & 


201215123 XE It Hc MA 
201215125 8Kaz | 15 


645 运行 效果 


第 19 步 ， 单 击 第 一 条 数据 的 “编辑 ”, 则 第 一 条 数据 处 于 编辑 状态 , 即 网 页 上 的 数据 是 
可 以 修改 的 ,效果 如 图 6-46 所 示 。 


i 
< 


201215121 

[201215122 
(201215123 
(201215125 


646 ”编辑 效果 


第 20 步 ” 把 李 勇 修改 为 李 勇 2, 把 年 龄 20 修改 为 30, 单 击 “ 更 新 "按钮 ,数据 更 新 到 数 
据 库 ,修改 如 图 6-47 所 示 。 
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Г Xp: X "Xi XD: Xp ml 


€ > С [D localhost: 


TS mamme 
|| 201215121 85882 30 
201215122500] 8 19 
201215123581 18 
201215125837 19 


图 6-47 更 新 后 效果 


第 21 步 ”停止 调试 ,打开 GridView 的 属性 对 话 框 ,设置 GridView 的 DataKeyNames Jš 
性 ,如 图 6-48 所 示 。 

第 22 步 。 单 击 DataKeyNames 后 的 按钮 ,打开 * 数 据 字 段 集合 编辑 器 "对 话 框 ,把 “可 用 
数据 字段 " 栏 中 的 sno 移 到 * 所 选 数据 字段 " 栏 中 ,如 图 6-49 所 示 。 


4 行为 
AllowSorting False 
AutoGenerateColum False 
AutoGenerateDelete False. 
AutoGenerateEditBu False 
AutoGenerateSelectl False 
ClientlDMode Inherit 
Enabled True 
EnableModelValidat True 
EnablePersistedSele False 
EnableSortingAndPa False 
EnableTheming True 
EnableViewState True 
SkinID 

ToolTip 

ViewStateMode Inherit 
Visible True 
可 访问 性 

AccessKey 

Caption 

CaptionAlign NotSet 
RowHeaderColumn 
Tabindex 0 
UseAccessibleHeade True 

4 数据 
(Expressions) 
ClientIDRowSuffix 


= - | 


sdept 


日 


DataSourcelD SqlDataSourcel 


L am. 


图 6-48  DataKeyNames 设置 图 649 数据 字段 集合 编辑 器 


注意 : 如 果 没 有 这 一 步 ,在 网 页 上 删除 纪录 时 ,会 出 现 错误 ,错误 如 图 6-50 所 示 。 

第 23 步 ” 打 开 “GridView 任务 ”对话 框 ,选择 “启用 分 页 "和 “启用 排序 "两 个 选项 ,如 
图 6-51 所 示 。 

第 24 步 打开 “GridView 属性 ”对话 框 ,将 GridView 的 PageSize 属性 的 值 设置 为 2, 如 
图 6-52 所 示 。 


Ce > 


用 程序 中 的 服务 器 错误 - 


Жж фк “加 snO 
W: 从 行当 前 Web RTI, алокат панаа, ULTERXEISRURATASEISUUEIEES. 
Ян: Sem Data SuCKen 59Езсерїоп {ЖЭИЕ "Qeon 

Ld 

执行 当前 Wob RENMBEIKTAADEORE.SURETERRTSASESSSREARRESBEAZIUROSRS. 
RARE: 


ат Boolean breakconnection) «2072422 
s 25 jlinternalconnect ion. Trente. арнап ekception, Boolean bresktonnection) +5063564 


Ntr raaa ier, Bim cediundler, здПагадеайег dataStream, BulkCopySipleResultSet bs1kcopytasdier, TásParserStateobject stat 
icient. 4 йш Jr 
АО а араат. Fésult, String methodkame, Boolean sendToPipe) +326 


ation operation) +394 
— Ya 
< Dictionary oldvaluei, резус espera ioca bad: eaa +3 
ло roe DID raider Se 


Бараат (Ser Tag enti unen) 
Dur Tras taset vent handler detteackeven (String eyentargument) +13 
过 andher sosrcecontrl, String eventar guent) “l 
ia np c 
etn О а, Boolean incledeStagesAftersyncPoint) +5563 


идэ: Woneon NET Framework 4030319. ASP NET r4 0 30319 1022 


图 6-50 出错 页 面 


4 布局 = 
CellPadding 1 
CellSpacing 0 
Height 
HorizontalAlign NotSet 
Width 
4 分 页 
AllowPaging True 
Pagelndex 0 
GridView 任务 b PagerSettings 
自动 套用 格式 … 2 
4 行为 
3888228888: |SalDataSourcel 四 AlowSorting сет 
配置 数据 源 .… AutoGenerateColum False 
27а AutoGenerateDelete False 
— AutoGenerateEditBu False 
SEP.. AutoGenerateSelectl False 
添加 新 列 . ClientIDMode Inherit 
Enabled True 
pnt: EnableModelValidat True 
移 除 列 EnablePersistedSele False 
F 启用 分 页 EnableSortingAndPa False 
EnableTheming True 
启用 排序 EnableViewState True 
yemas SkiniD 
ToolTip 
BERIE ViewStateMode Inherit 
Visible True 
团 启用 选 定 内 容 5 ЭНЕНЕ 
编辑 模板 AccessKey 加 
PI 


图 6-51 启动 排序 和 分 页 图 6-52  PageSize 设置 


第 25 步 ”启动 调试 ,网 页 上 以 分 页 效果 展示 学 生 信 息 ,并 且 表 头 上 的 文字 下 方 具 有 下 


划 线 ,如 图 6-53 所 示 。 


第 26 步 单 击 网 页 上 “分 页 "位 置 的 数字 "2”, 则 打开 第 二 页 的 学 生 信息 ,网 页 效果 如 


图 6-54 所 示 。 


第 27 步 。 单 击 网 页 上 “ 表 头 "位 置 的 “年 龄 ” , 则 学 生 按 照 “ 年 龄 "排序 ,网 页 效果 如 图 6- 


55 所 示 。 


第 28 步 停止 调试 ,打开 “GridView 任务 "对 话 框 , 单 击 “自动 套用 格式 ” ,打开 * 自动 套 


用 格式 "对 话 框 ,选中 “传统 型 " ,如 图 6-56 所 示 。 
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学 号 


201215121 


ESPE 


201215122| 


зо Ks 
BUR Hr | ks 


12 


6-53 ”运行 效果 


D localhost:12532/chap6- х 


€ > C Ë localhost:12532/chap6-3/Default.aspx 


图 6-54 第 二 页 效果 


D localhost12532/chapó- x V. 


图 6-55 ”排序 效果 


图 6-56 ”自动 套用 格式 
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第 29 步 ”启动 调试 ,打开 网 页 ,效果 如 图 6-57 所 示 。 


Г слала FS x /' Су localhost12532/chapó- x \ 

€ > Q |D localhost:12532/chap6-3/Default.aspx 空 三 
228 ИА Ни ЖЛ 

201215121 李 勇 2 B 30 cs 编辑 选择 删除 

201215122 ІЖ Ж 19 cs 88 选择 删除 


图 6-57 运行 效果 


小 提示 : 本 任务 采用 GridView 绑 定数 据 源 SqlDataSource 控件 实现 了 修改 和 删除 ,还 有 
GridView 可 以 结合 DataSet 实现 本 任务 功能 ,但 是 比 本 任务 实现 复杂 。 

【任务 小 结 】 

本 任务 通过 GridView 和 SqlDataSource 控件 实现 了 学 生 信息 的 呈现 ,修改 和 删除 ,以 及 
呈现 时 的 分 页 与 排序 。 

涉及 到 的 知识 和 技术 主要 有 SqlDataSource 控件 的 设置 ,GridView 控件 的 设置 和 一 些 常 
用 属性 以 及 列 的 设置 ,比如 分 页 设置 .排序 设置 和 列 名 设置 等 。 

【拓展 提高 】 

1. 使 用 GridView 控件 和 DataSet 对 象 呈现 学 生 信 息 

第 1 步 在 chap6-2 网 站 中 ,添加 新 项 Web 窗 体 Default2. aspx, 从 工具 箱 中 拖 入 一 个 
GridView。 编 辑 GridView 的 列 , 添加 一 个 BoundField 列 , 设 置 其 HeaderText 为 “学 号 ”; 
DataField 为 “sno”, 如 图 6-58 所 示 。 


crm 5359013 El 1. 
Jeur Гао а TTA TESTE] 


пан] lan) EEEE ¿ese cx [7 


Г Gm) Lom) 


етап 


图 6-58 设置 CridView 列 
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第 2 步 ”仿照 第 一 列 ,添加 姓名 、 性 别 、 年 龄 和 系 别 4 列 ,并 设置 其 HeaderText 和 
DataField 属性 ;取消 “自动 生成 字段 ”选项 ,效果 如 图 6-59 所 示 。 


зе 二 -. w ЕЖЕ: 
可 用 字段 (A): BoundField 属性 (P): 
He z 
-E CheckBoxfield 
L- E] HyperLinkField 
HE ImageField ] 
| ButtonField 
t] CommandField 
143] TemplateField + 
Жр) 
GST 
mes [* | 
m 
Gen ыы 
mex UX | 
2х8 
| Баана) 8280808 Templotefield 
[ = J[ w jJ ! 
图 6-59 配置 列 后 效果 
第 3 步 打开 Defauli2. aspx. cs 文件 ,如 图 6-60 所 示 。 


оо chap6-3 - Microsoft Visual Studio (B8) = m X 


ВеМЕИЕГТЈЕТ ТЕТЕ УЕ УТС -]|®: 
ПЕ ЕЕ ЕЕЕ 


Defaukt2.aspxcs x 


*t$Default2 > | 4S Page Load(object sender, EventArgs e) =) 
Busing System; 

using Systen. Collections. Generic; 

using System. Linq: 

using System. Veb: 

using System. Veb. UI: 

using System. Veb. UI. VebControls; 


Ejpublic partial class Default? : System. Veb. UI. Page 


protected void Page Load(object sender, Eventárgs e) 
t 


wo% -a ж ] 5 


图 6-60 Default2. aspx. cs 文件 内 容 


第 4 步 ， 添 加 两 条 using, 代 码 如 下 : 
using System. Data; 
using System. Data .SqlClient; 
在 Page. Load 方法 中 添加 代码 如 下 : 
string connectionString -"Data Source —.;Initial Catalog -studentIb; Integrated Security =True"; 
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SqlConnecticn conn =new SqlConnecticn (connectionString) ; 
SqlCoamand ard new SqlComand("select * fram student", ооп); 
DataSet ds -new DataSet () ; 

Sqlpatandapter sda -new SqlDataAdepter (aud) ; 

Sda.Fill(ds, "student") ; 

this.GridViewl .DataScurce =ds Tables [0] .DefaultView; 
this.GridViewl .DataBird() ; 


添加 代码 后 效果 如 图 6-61 所 示 。 


чө chap6-3 - Microsoft Visual SS 天) кезе шше] 
X) жаю mm) ШЫЮ ИЫ) AB mD тм) дл IAM (келис IUS SUN SOW 


ES Дова(8әјаох веди, Бунтар а 
ч (Mthis. IsPostBack) 
{ 


string comectionString = 


图 6-61  Defaul2. aspx. cs 编写 代码 效果 


2. GridView 和 DetailsView 控件 配合 使 用 

第 1 步 在 chap6-3 网 站 中 ,添加 Web Ж Default3. aspx. 

第 2 步 在 打开 的 Defauli3. aspx 中 , 放 入 两 个 SqlDataSource 控件 .一 个 Grid 控件 和 一 
个 DetailsView 控件 ,效果 如 图 6-62 所 示 。 

第 3 步 SqlDataSourcel 的 配置 与 本 章 任务 6-1 相同 ,SqlDataSource2 的 配置 略 有 差异 , 需 
要 在 配置 过 程 中 加 入 WHERE +J, WHERE 子 句 的 配置 如 图 6-63 所 示 , 单 击 配置 select 语句 
界面 中 的 “WHERE 子 句 "按钮 ,弹出 “添加 WHERE 子 名 "对话 框 ,填写 内 容 如 图 6-63 所 示 。 

第 4 步 ”在 第 3 步 的 基础 上 , 单 击 “ 添 加 "按钮 , 则 把 第 3 步 的 设置 添加 为 WHERE + 
句 ,如 图 6-64 所 示 。 

第 5 步 ， 单 击 “ 确 定 "按钮 ,关闭 数据 源 配 置 。 

第 6 步 BUE GridView 控件 ,GridViewl 数据 源 设置 为 SqlDataSourcel , GridView2 数据 
源 设 置 为 SqlDataSource2 , 为 GridViewl 添加 一 个 CommandFeild 选择 命令 列 , 如 
图 6-65 所 示 。 
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Пво%Г 
SqlDataSource - SqlDataSourcel 


abc abc abc 

abc abc abc 

abc abc abc 

abc Јас јас | 
abc abc abc 
Colum ^ abc | 

[Columnl abc 

Colum2 abc 


SqlDataSource - SqlDataSource2 


Column0 Columnl Column2 


图 6-62 放 入 控件 后 的 Default3. aspx 设计 界面 


Бат rn Ve or sj 
rE E HEERE ва о) 
СІЕЯ Је @ Ia асат Јо Jesu А =-)= = ml. 
—— 
Fr | кисы [mamar 
ЕІ A 
E 
0] wama naa ENE? 
R| c wamamusq mawsamma | ^o ens 
| mawamaganpnmn = J LL 
a m — lam sss. a 
labe (student E z] койу; 
or = 
Colu [ae = " 
Col m > J 
Cotu JE mame samat . 
id [TES p cmn] 
рл EE 
за тах a - 
застае 
эшет "FROM ншде ин 
Cm ) =) 
zm = 
Geran ami iis ehe [eri hs htnc E 


ETT 


图 6-63  SqlDataSource2. 的 配置 


向 各 的 WHERE аана, Эзир SHP Ramil. BIMNECECH RENE 
mü. 
Po: emus 
ERAP) 
яо: 
SQL жазб а 
| Ii EA) 
WHERE FAW: 
samast П homm | 


ce] 


图 6-64 WHERE 子 句 
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[r — 


| SqlDataSource - SqlDataSourcel 


| SqlDataSource - SqlDataSource2 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


sname ssex sage sdept 
abcabc abc 0 ^ abc 
jabc|abc abc 1 abc 
jabclabc abc 2 ас 
abclabc abc 3 abc 
jabc|iabc abc 4 abc 


图 6-65 配置 好 界面 
第 7 步 ” 启动 调试 ,网 页 运行 效果 如 图 6-66 所 示 。 


D localhost1253: x 


€ > CD localhost:12532/chap6-3/Default3.aspx 


sname|ssex|sage| sdept| 


201215121 


勇 2 | 男 30 


201215122 


JR Ж пэ 


201215123 


lb p 8 


| 1201215125) 


B 19 


IS 


s лез 
Em 
选择 


图 6-66 


运行 效果 


第 8 步 单 击 学 生 王 敏 , 网 页 效果 如 图 6-67 所 示 。 
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D lecalhost1253: x V... 


1201215121 


勇 2 


201215122 


JR 


201215123 


Bt 


201215125 


sno |201215123 


6-67 ”选中 学 生 王 敏 效 果 


任务 6-4 使 用 ListView 展示 课程 信息 


【任务 描述 】 

小 王 把 做 好 的 项 目 给 客户 看 ,客户 说 课程 信息 在 页 面 上 展示 的 格式 有 问题 ,他 们 不 喜 
欢 , 能 不 能 换 其 他 形式 展示 课程 信息 ,小 王 说 没有 问题 ,可 使 用 ListView 控件 ,功能 强大 ,使 
用 灵活 ,这 里 有 好 几 种 格式 ,可 看 看 喜欢 哪 一 种 。 


【任务 目的 】 
(1) 掌握 数据 绑 定 控件 ListView 的 使 用 。 
(2) 掌握 DataPager 控件 配合 ListView 控件 ,实现 分 页 功能 。 


【任务 分 析 】 

信息 的 展示 有 多 种 形式 ,以 表格 的 形式 展示 是 最 常用 的 形式 ,还 有 一 些 形式 也 是 十 分 常 
用 的 ,比如 平 铺 、 项 目 符号 列表 йй .单行 等 形式 。 在 ASP . NET 中 ,ListView 提供 了 多 种 数据 
展示 形式 ,包括 刚才 提 到 的 形式 。 为 了 提供 更 好 的 分 页 效果 ,ASP .NET 还 提供 了 DataPager 
控件 ,这 个 控件 配合 ListView 使 用 ,功能 强大 ,效果 良好 。 


【基础 知识 】 

1. ListView 控件 概述 

ListView 控件 是 ASP . NET 中 最 灵活 的 数据 绑 定 控件 ,不 但 可 以 实现 GridView 网 络 型 
控件 ,还 可 以 实现 DataList 控件 的 分 列 分 页 显示 。 还 有 其 他 的 一 些 显示 形式 ,可 见 ListView 
功能 强大 ,设计 灵活 。 

2. ListView 常用 属性 

ListView 的 常用 属性 如 表 6-7 所 示 。 


表 6-7 ListView 的 常用 属性 


名 Ж 说 明 
DataKeyNames 获取 或 设置 一 个 数组 ,该 数组 包含 了 显示 在 ListView 控件 中 的 主键 字段 名 称 
Editltem 获取 List View 控件 中 处 于 编辑 模式 的 项 
Insertltem 获取 ListView 控件 的 插入 项 


获取 一 个 ListViewDataltem 对 象 集合 ,这 些 对 象 表示 ListView 控件 中 的 当前 数据 页 的 
Items 数据 项 


ItemTemplate 获取 或 设置 ListView 控件 中 的 数据 项 的 自 定 义 内 容 
SelectedIndex 获取 或 设置 ListView 控件 中 的 选 定 项 的 索引 


3. ListView 控件 模板 
ListView 控件 模板 如 表 6-8 所 示 。 


表 6-8 ListView 控件 模板 


名 K 说 明 
AlternatingltemTemplate 交替 项 目 模板 ,用 不 同 的 标记 显示 交替 项 目 ,便于 查看 连续 不 断 的 项 目 
EditltemTemplate 编辑 项 目 模板 
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名 Ж 说 — HB 
EmptyDataTemplate 空 数据 模板 ,数据 源 返 回 空 
EmptyltemTemplate 空 项 目 模板 ,项 目 为 空 


GroupSeparatorTemplate 


组 分 割 模板 ,控制 项 目 内 容 的 显示 


GroupTemplate 组 模板 
InsertltemTemplate 插入 项 目 模板 
InsertSeparatorTemplate 插入 分 割 模 板 
ItemSerparatorTemplate 项 目 分 割 模 板 
ItemTemplate 项 目 模板 
LayoutTemplate 布局 模板 
SelectedItemTemplate 已 选择 项 目 模板 


【任务 实施 】 

第 1 步 ”新建 网 站 chap6-4 ,添加 Web 窗 体 Default. aspx; 

第 2 步 In) Web 窗 体 Default. aspx 添加 一 个 SqlDataSource 和 一 个 ListView 控件 ,如 图 
6-68 所 示 。 


Id] ы ——PÜ e 
| SglDataSource - SqlDataSource1 


| ListView - ListView1 
| 选择 要 为 ListView 提供 数据 的 数据 源 . 
| ItemTemplate 是 必需 的 


图 6-68 放 入 控件 后 的 设计 界面 


第 3 步 ” 配 置 数据 源 ,和 前 边 的 基本 相同 ,唯一 不 同 的 是 在 “指定 来 自 表 或 试图 的 列 ” 
选中 course 表 , 而 不 是 student 表 。 
第 4 步 H ListView 选中 数据 源 ,数据 源 为 刚刚 创建 的 SqlDataSourcel , 如 图 6-69 所 示 。 


Defaultaspx* x 


一 
aspi:listview#ListViewi| 


ListView - UstViewl 


选择 “配置 ListView” 任 务 以 选择 布局 。 远近 数据 源 :|SqlDataSourcel 
ftemTemplate 之 后 ,可 以 从 一 - 
ED. RENER.. 
o ыас 
EE ListView... 8 
4 , 
[з + |o se las | [ «html» || «body» || «formsformi»] <div <asp:ListView#ListView1> N 
СЕЕ Ñ—yos—SsII 


图 6-69 配置 ListView 


第 5 步 单 击 “ListView 任务 "中 的 “配置 ListView” ,打开 “配置 ListView” 对 话 框 , 选 中 
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“选择 布局 ”中 的 “项 目 符号 列表 ”项 ;选中 “选择 样式 ”中 的 “专业 型 "项 ,如 图 6-70 所 示 。 


选择 布局 (L): 


za 
ж 
流 


ccredit: BRIE 


d 


图 6-70 配置 ListView 


95 6 27 1 Default. aspx 中 放 入 一 个 DataPager, 单 击 DataPager 右上 边 的 ”> "符号 , 然 
后 单 击 “编辑 页 导航 字段 " ,打开 < 字段 "对 话 框 ,双击 ″“ 下 一 页 "人 上 一 页 "页 导航 字段 ”, 刀 
图 6-71 所 示 。 


CROWD / E ‚йэ NR 


gum 


рыи тшн | 
| = manana 


E 


[ am | 


las] 


图 6-71 配置 DataPager 
第 7 步 设置 DataPager ,把 DataPager 的 PageSize 属性 设置 为 3,PagedControlld 设置 为 
ListViewl ,如 图 6-72 所 示 。 
第 8 步 ” 启动 调试 ,页 面 效 果 如 图 6-73 所 示 。 


第 9 步 单 击 网 页 上 的 “下 一 页 "按钮 ,网 页 上 的 课程 信息 发 生变 化 ,页 面 效果 如 图 6- 
74 所 示 。 
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属性 ET 


DataPagerl System. Web.UL WebControls.Datal ~ 


4 $m 
PagedControllD. 
Радебіге 
QueryStringField 


D localhost:7521/chap6-4, x V. 
€ > © [localhost7521/chap6-4/Default.aspx 


р 
* cno: 2 
EX 


Credit: 2 


上 一 页 下 一 页 


图 6-72 DataPager 属性 图 6-73 运行 效果 


D localhost:7521/chap6-4, x V. 
3 © |D localhost:7521/chap6-4/Default.aspx 


图 6-74 单 击 下 一 页 网 页 效果 


【任务 小 结 】 
本 任务 使 用 ListView 和 DataPager 控件 实现 了 课程 信息 的 分 页 显示 ,任务 实现 的 关键 是 
数据 源 配 置 List View 的 布局 配置 DataPager 的 字段 配置 。 


【拓展 提高 】 

使 用 FormView 管理 课程 信息 的 方法 如 下 : 

第 1 步 在 网 站 chap6-4 中 添加 Web 窗 体 Default2. aspx, 

第 2 步 在 Defaul2. aspx 中 添加 一 个 SqlDataSource 控件 和 一 个 FormView 控件 ,如 图 
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6-75 所 示 。 


| SqlDataSource - SalDataSourcet | 


i FormView - FormViewl. 
| 右 二 或 先 择 “篇 名 模板 ”任务 来 编辑 模板 内 容 。 
| 需要 使 用 HemTemplate。 


图 6-75 放 入 控件 后 的 设计 界面 


第 3 步 设置 SqlDataSource 控件 ,其 设置 过 程 与 任务 6-3 中 的 数据 源 设置 相同 ,不 再 重 
复 说 明 。 

第 4 步 设置 FormView 的 数据 源 为 SqlDataSourcel, 并 选中 “启用 分 页 ”选项 ,如 
图 6-76 所 示 。 


Default2aspx* x 


Е [SalDataSource1 


口 拆 分 | 回 源 | <body>||<form#forml>||<div>| «asp:FormViewsFormViewl» 


图 6-76 配置 FormView 


第 5 步 ”启动 调试 ,网 页 效果 如 图 6-77 所 示 。 


D localhost:7521/chap6-4. x 
€ > Ç |D localhost:7521/chap6-4/Default2.aspx <] = 


| 1234567 


图 6-77 运行 效果 


第 6 步 单 击 网 页 上 的 “编辑 "按钮 ,信息 处 于 可 修改 状态 ,并 且 按 钮 变 为 “更 新 ”和 “ 取 
消 ”。 修 改 后 , 单 击 “更 新 "按钮 ,把 修改 后 的 数据 更 新 到 数据 库 , 单 击 “ 取 消 " 按 钮 , 则 取消 修 
改 , 即 修改 无 效 。 如 图 6-78 所 示 。 
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| 了 四 localhost7521chap6-4 x 
€ > С [D localhost7521/chap6-4/Default2.aspx vy| 三 


cno: 1 
cname: 


српо: 


ccredit: 
更 新 取消 
1234561 


6-8 ” 单 击 编辑 效果 


第 7 步 单 击 网 页 上 的 “新 建 "按钮 , 则 网 页 上 出 现 一 个 Form, 用 户 可 以 录入 数据 。 录 
入 数据 后 , 单 击 “ 插 入 "按钮 ,数据 保存 到 数据 库 , 单 击 “ 取 消 "按钮 , 则 添加 无 效 。 如 图 6-79 
所 示 。 


n localhost7521/chap6-4, x 
€ > С [D localhost7521/chap6-4/Default2.aspx 3| Ж 


cno: 


cname: 


српо: 


插入 取消 


图 6-79 单 击 新 建 效 果 


第 8 步 单 击 网 页 上 的 “分 页 "数字 , 即 可 翻 页 ,查看 对 应 页 数 的 信息 。 单 击 “6” ,网 页 
显示 第 6 条 数据 ,如 图 6-80 所 示 。 


D localhost7521/chap6-4 х h 


€ > C [localhost7521/chap6-4/Default2.aspx 5% 三 


1234561 


图 6-80 单 击 分 页 6 效果 


四 、 项 目 小 结 
本 项 目 通过 4 个 任务 学 习 了 数据 源 控件 和 数据 敌 定 控件 的 使 用 , 主要 掌握 它们 的 常用 
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属性 和 方法 及 其 配置 ,重点 内 容 是 SqlDataSource 数据 源 控件 和 GridView 数据 绑 定 控件 。 


五 、 项 目 考核 


1. 填空 题 
(1) 在 ASP .NET 应 用 程序 中 ,数据 库 “ 连 接 字 符 串 "通常 情况 下 会 保存 在 配置 文件 中 ， 
此 配置 文件 名 称 为 
(2) 在 配置 SqlDataSource 数据 源 控件 过 程 中 ,配置 SELECT 语句 是 十 分 重要 的 一 步 ,其 
配置 必须 设置 和 o 
(3) SqlDataSource 控件 可 以 包括 4 个 命令 参数 : 和 
(4) GridView 控件 自 带 的 分 页 模式 分 别 是 е Ч 和 
(5) 若 要 启动 DetailsView 控件 的 分 页 行为 ,需要 设置 属性 ,把 其 值 设 置 为 
true, 则 其 页 面 大 小 是 固定 的 ,始终 是 一 行 。 
2. 选择 题 
(1) GridView 中 的 Columns 集合 的 字段 包括 ( ) 
A. BoundField B. HyperLInkField 
C. CommandField D. CheckBoxField 
(2) 在 ASP . NET 中 ,数据 绑 定 控件 绑 定 并 显示 一 张 表 的 数据 ,需要 设置 其 ( ) 属性 
指定 数据 源 。 
A. ID B. Style C. DataSource D. DataBind 
3. 简 答题 
(1) ASP .NET 中 都 有 哪些 数据 源 控件 ,每 种 数据 源 控件 的 作用 是 什么 ? 
(2) SqlDataSource 数据 源 控件 的 主要 属性 是 什么 ? 
(3) 使 用 数据 源 配置 向 导 设置 SqlDataSource 控件 的 属性 主要 包括 哪些 步骤? 
(4) FE ASP .NET 4.0 中 ,都 有 哪些 控件 可 以 绑 定数 据 ? 
(5) 简 述 DropDownList 控件 进行 数据 绑 定 时 ,显示 的 数据 字段 和 值 选中 字段 的 含义 ? 
(6) ListView 控件 进行 布局 ,有 几 种 类 型 可 以 选择 ? 
(7) FormView 控件 支持 的 模板 有 哪些 ? 
(8) GridView 控件 有 哪些 常用 属性 和 常用 时 间 ? 
4. 上 机 操作 题 
(1) 有 一 个 名 为 Albums 的 数据 库 表 ,包含 下 列 字段 : AlbumID, Name, Artist 和 
DatePurchased。 使 用 SqlDataSource 控件 检索 唱片 的 信息 ,并 按 唱片 名 称 字 母 顺序 排序 。 
(2) 数据 库 中 有 一 个 课程 (course) 表 ,请 设计 制作 一 个 课程 下 拉 框 ,显示 课程 名 ,下 拉 
框 的 值 为 课程 的 编号 。 
(3) 使 用 GridView 和 SqlDataSource 控件 实现 课程 信息 的 呈现 ,修改 和 删除 。 
(4) 使 用 ListView 和 DataPager 控件 分 页 实现 学 生 信息 。 
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项 目 7 ASP .NET AJAX 
一 、 引 言 


AJAX 不 是 新 的 编程 语言 , 而 是 一 种 使 用 现 有 标准 的 新 方法 , 它 是 Asynchronous 
JavaScript and XML 的 简写 ,通过 在 后 台 与 服务 器 进行 少量 数据 交换 ,AJAX 可 以 使 网 页 实现 
异步 更 新 。 这 意味 着 可 以 在 不 重新 加 载 整个 网 页 的 情况 下 ,对 网 页 的 某 部 分 进行 更 新 。 
AJAX 的 出 现 , 揭 开 了 无 刷新 页 面 时 代 的 序幕 ,正在 代替 传统 Web 技术 。 

ASP .NET 封装 了 AJAX 的 实现 ,使 用 拖 放 控件 .设置 属性 就 能 实现 АТАХ 效果 ,其 思路 
独具匠心 ,开发 效率 成 倍 提 升 。ASP . NET 提供 三 个 AJAX 控件 : ScriptManager , UpdatePanel 
和 Timer, 


二 、 项 目 要 点 


本 项 目 使 用 ASP . NET 的 AJAX 控件 开发 具有 AJAX 效果 的 应 用 程序 ,讲解 了 使 用 
ScriptManager „UpdatePanel 和 Timer 这 3 个 控件 开发 应 用 程序 ,为 了 更 好 地 开发 AJAX 项 目 ， 
还 讲解 了 AJAX 扩展 包 的 使 用 。 


三 x 尾 务 


任务 7-1 使 用 UpdatePanel 控件 


【任务 描述 】 

小 王 项 目 开 发 完成 后 给 用 户 演 示 ,用户 对 项 目的 页 面 跳 转 十 分 反感 ,他 们 要 求 和 他 们 现 
用 的 很 多 程序 一 样 ,不 能 出 现 页 面 跳 转 , 想 要 一 个 系统 ,而 不 是 一 个 网 站 。 在 这 种 情况 下 ,小 
王 只 能 使 用 AJAX 技术 了 。 


【任务 目的 】 

(1) 了 解 AJAX 技术 。 

(2) 了 解 服务 器 端 АТАХ 和 客户 端 AJAX。 
(3) 掌握 UpdatePanel 控件 的 简单 应 用 。 


【任务 分 析 】 

畅游 在 网 络 的 海洋 ,跳动 在 网 页 之 上 ,有 的 网 页 如 同 海浪 般 “ 闪 屏 ”, 有 的 网 页 如 同 湖面 
般 “ 宁 静 ” ,那么 是 什么 样 的 技术 实现 了 海浪 的 “ 漠 涌 "的 内 容 却 表现 得 如 此 “平静 ”"? 这 就 
是 AJAX 技术 。AJAX 在 客户 端 浏 览 器 运行 ,不 但 响应 速度 快 ,而 且 没 有 “ 闪 屏 ”的 现象 , 那 
么 本 章 就 要 讲解 AJAX 技术 。 
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【基础 知识 】 

1. AJAX 简介 

AJAX 的 全 称 是 Asynchronous JavaScript and XML, Bl 5:25 JavaScript 和 XML 技术 ,是 指 
一 种 创建 交互 式 网 页 应 用 的 开发 技术 。AJAX 是 由 JavaScript 脚本 语言 .CSS 样式 表 、 
XMLHttpRequest 数据 交换 对 象 和 DOM 文档 对 象 等 多 种 技术 组 合 在 一 起 ,形成 了 功能 强大 
的 AJAX 技术 。 

Ajax 这 个 名 词 的 发 明 人 是 Jess James Сатен, 其 幕后 技术 是 微软 为 了 支持 它 自己 的 电子 
邮件 Web 客户 端 最 早 发 明 的 ,而 大 力 推 广 并 且 使 AJAX 技术 炙手可热 的 是 Google。Google 
发 布 的 Gmail „Google Suggest 等 应 用 最 终 让 人 们 了 解 了 什么 是 AJAX。 

2. AJAX 的 拼写 

细心 的 读者 可 能 发 现 本 章 使 用 了 AJAX 和 Ajax ,这 两 种 写法 谁 对 谁 错 ,应 该 采用 哪 种 方 
ЭШ? Ajax 的 写法 是 Jess James Garrett 提出 和 创建 的 ,并 且 他 坚持 认为 就 应 该 拼写 为 Ajax , 
而 微软 坚持 认为 所 有 字母 都 大 写 ,就 像 一 个 特殊 的 缩写 词 一 样 ,采用 AJAX 的 写法 。 一 般 在 
代表 微软 产品 名 时 使 用 AJAX。 

ASP . NET 是 一 项 用 来 创建 Web 应 用 的 服务 器 端 技术 ,几乎 所 有 的 工作 都 发 生 在 Web 
服务 器 而 不 是 Web 浏览 器 ,在 ASP . NET 页 面 上 执行 任何 一 个 行为 一 一 单 击 一 个 按钮 或 对 
GridView 进行 排序 一 一 整个 页 面 都 会 被 回 传 到 Web 服务 器 ,在 传统 的 Web 应 用 模式 中 ,页 
面 中 用 户 的 每 一 次 操作 都 将 触发 一 次 返回 Web 服务 器 的 HTTP 请 求 , 服 务 器 进行 相应 的 处 
理 ( 获 得 数据 .运行 于 不 同 的 系统 会 话 ) 后 ,返回 一 个 HTML 页 面 给 客户 端 ,其 过 程 如 图 7-1 
所 示 。 


服务 器 端 
HTTP 请 米 
————————» 
三 数据 存储 ， 
HIML(S) 协 议 传输 V AERE 


— — —* | 数据 和 继 
承 系统 


HTML+CSS 数 据 | Web 服 务 器 


图 7-1 Web 应 用 的 传统 模型 


仔细 分 析 回 传 过 程 ,这 样 做 的 效率 非常 低 。 当 在 ASP . NET 页 面 执行 回 传 时 ,整个 页 面 
都 将 通过 因特网 从 浏览 器 传输 到 服务 器 。 接 下 来 ,页 面 所属 的 . NET 类 必须 重新 呈现 整个 
页 面 。 最 后 ,完成 页 面 又 必须 通过 因特网 发 送 回 浏览 器 。 整 个 漫长 .缓慢 ,痛苦 难 耐 的 过 程 
是 必须 发 生 的 ,即使 只 修改 了 页 面 中 很 小 的 一 部 分 ,同时 浏览 的 网 页 也 就 出 现 了 波浪 般 的 
“WBE” o 

Web 开发 者 们 发 现 ,如 果 想 要 创建 出 真正 伟大 的 应 用 ,就 必须 舍弃 服务 器 端的 稳定 ,而 
转向 客户 端的 自由 ,AJAX 技术 就 是 如 此 。 

在 AJAX 应 用 中 ,页面 中 用 户 的 操作 将 通过 AJAX 引擎 与 服务 器 端 进行 通信 ,然后 将 返 
回 结果 提交 给 客户 端 页 面 的 AJAX 引擎 ,再 由 AJAX 引擎 来 决定 将 这 些 数据 显示 到 页 面 的 
指定 位 置 ,如 图 7-2 所 示 。 
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图 7-2 Web 应 用 的 AJAX 模型 


从 图 7-1 和 图 7-2 可 以 看 出 ,对 于 每 个 用 户 的 行为 ,传统 的 Web 应 用 模型 中 将 生成 一 次 
HTTP 请 求 ,而 在 AJAX 应 用 开发 模型 中 ,将 变 成 对 AJAX 引擎 的 JavaScript 调用 。 在 AJAX 
应 用 开发 模型 中 通过 JavaSeript 实现 在 不 刷新 整个 页 面 的 情况 下 ,对 部 分 数据 进行 更 新 ,从 
而 降低 了 网 络 流量 ,给 用 户 带 来 了 更 好 的 体验 。 

3. AJAX 的 优点 及 应 用 

AJAX 的 优点 如 下 : 

(1) 性 能 优良 。AJAX 拥有 更 佳 的 性 能 ,速度 更 快 ,不 必 等 待 服务 器 响应 ,避免 重新 加 
载 整个 网 页 造成 页 面 闪 动 。 

(2) 功能 强大 。 提 供 更 多 客户 端 组 件 ,可 扩展 功能 。 这 些 客户 端 组 件 , 安 装 后 与 Visual 
Studio 2010 自 带 控件 使 用 方法 相同 ,丰富 的 AJAX 扩展 控件 可 以 给 编程 带 来 极 大 的 方便 ,可 
以 实现 Visual Studio 2010 自身 不 能 实现 的 功能 。 

(3) 局 部 回调 。AJAX 可 实现 页 面 的 局 部 回调 ,网 页 不 必 整 个 页 面 进行 更 新 ,只 需要 局 
部 更 新 即 可 。 类 似 一 件 衣 服 , 破 了 一 个 洞 ,不 使 用 AJAX 技术 ,只 能 重新 做 一 件 衣服 ,但 使 用 
AJAX 技术 ,哪里 破 了 补 哪 里 ,其 他 地 方 一 律 原封 不 动 。 

(4) 兼容 性 好 。ASP . NET AJAX 可 以 在 各 种 浏览 器 上 运行 ,具有 跨 浏览 器 的 特性 。 
AJAX 不 限制 浏览 器 ,在 绝 大 多 数 的 浏览 器 上 表现 良好 。 

但 是 AJAX 也 不 是 万 能 的 ,在 适宜 的 场合 使 用 才能 充分 发 挥 它 的 长 处 ,改善 系统 性 能 和 
用 户 体验 ,绝对 不 可 以 为 了 技术 而 滥用 。AJAX 的 特点 在 于 异步 交互 .动态 更 新 Web 页 面 ， 
因此 它 适用 范围 是 交互 较 多 ,频繁 读 取 数 据 的 Web 应 用 ,主要 应 用 于 数据 验证 、 按 需 取 数 
据 、 自 动 更 新 页 面 等 场景 ,目前 已 经 出 现 了 许多 基于 AJAX 的 应 用 。 

AJAX 应 用 是 使 用 最 原始 的 浏览 器 技术 (如 JavaScript 和 DOM) 4i * 9 Web 应 用 ,用 户 
界面 层 位 于 浏览 器 中 ,业务 逻辑 层 和 数据 访问 层 位 于 服务 器 上 ,用 户 界面 层 通 过 Web 服务 
访问 业务 逻辑 层 。 

Google Suggest 是 一 个 值得 称道 的 AJAX 应 用 ,确立 了 AJAX 的 地 位 与 应 用 。Google 
Suggest 不 仅 很 好 地 设置 了 下 拉 区 ,还 会 在 输入 框 中 自动 输入 最 有 可 能 的 答案 ,在 下 拉 区 中 
可 以 使 用 上 下 箭头 或 者 鼠标 选择 搜索 词 。 下 拉 区 为 每 个 可 能 的 搜索 词 都 提供 了 一 些 结果 ， 
用 户 可 以 清楚 地 了 解 当 前 输入 的 搜索 词 是 否 合适 。 百 度 也 已 经 实现 此 功能 ,效果 如 图 7-3 
所 示 。 

Google 地 图 .Google Docs ,Google Gmail .Amazon 的 搜索 等 都 是 AJAX 的 典型 应 用 , 感 兴 
趣 的 读者 可 以 自己 阅读 相关 参考 文献 和 访问 网 站 了 解 。 
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图 7-3 AJAX 在 百度 搜索 中 应 用 


4. 服务 器 端 AJAX 与 客户 端 AJAX 

微软 公司 一 方面 希望 为 现 有 ASP . NET 开发 者 提供 一 个 简单 的 方法 来 实现 AJAX 功能 
而 不 用 去 学 习 JavaScript, 微软 公司 也 希望 为 Web 开发 者 提供 一 套 能 够 建立 纯粹 客户 端 
AJAX 应 用 的 工具 ,因此 ,微软 公司 既 拥有 服务 器 端 AJAX 框架 ,也 拥有 客户 端 AJAX 框架 。 

如 果 想 更 新 现 有 ASP . NET 应 用 使 其 具备 AJAX 的 特点 ,可 以 使 用 服务 器 端 AJAX HE 
架 。 利 用 服务 器 端 框架 ,无 须 编 写 一 行 JavaScript 代码 ,可 以 继续 使 用 标准 的 方式 通过 服务 
器 端 控件 创建 ASP . NET 页 面 。 

服务 器 端 框架 的 优点 是 为 现 有 ASP . NET 开发 者 提供 了 一 种 开发 AJAX 的 简便 方法 ， 
其 缺点 是 无 法 完全 摆脱 服务 器 端 框架 的 问题 ,在 执行 任何 客户 端 行为 时 ,仍然 需要 回 到 服务 
器 上 。 

微软 客户 端 AJAX 框架 更 强调 客户 端 。 当 使 用 微软 客户 端 AJAX 框架 创建 应 用 时 , 必 
须 使 用 JavaScript。 使 用 客户 端 框架 创建 应 用 的 优点 是 可 以 创建 内 容 丰 富 响 应 友好 的 Web 
应 用 ,可 以 创建 和 桌面 应 用 一 样 具 有 和 良好 交互 性 的 Web 应 用 。 而 其 缺点 是 ,目前 微软 客户 
端 框架 并 不 是 十 分 成 熟 。 

在 ASP .NET 3.5 之 前 ,ASP . NET 自身 并 不 支持 
AJAX 的 应 用 ,需要 下 载 和 安装 AJAX 并 配置 后 才能 使 
Ho ASP .NET3.5 之 后 的 版 本 ,AJAX 已 经 成 为 . NET HE 
架 的 原生 功能 ,可 以 直接 拖 动 АТАХ 控件 , 像 普通 控件 一 
样 (如 图 74 所 示 ) ,实现 Web 页 面 的 无 刷新 功能 。 图 7-4 AJAX Extensions 工具 栏 

5. 脚本 管理 控件 ( ScriptManager ) 

TE ASP . NET AJAX 中 ,最 核心 的 控件 是 ScriptManager 服务 器 控件 。 通 过 使 用 
ScriptManager 能 够 对 整个 页 面 进行 局 部 更 新 管理 。ScriptManager 用 来 处 理 页 面 上 的 局 部 更 
新 ,同时 生成 相关 代理 脚本 以 便 能 够 通过 JavaScript 访问 Web 服务 。 在 对 页 面 进行 全 局 管 
理 时 ,每 个 要 使 用 AJAX 功能 的 页 面 都 需要 使 用 一 个 ScriptManager 控件 , 且 只 能 被 使 用 一 
次 ,如 图 7-5 所 示 。 

ScriptManager 控件 的 属性 如 表 7-1 所 示 。 
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图 7-5 ScriptManager 控件 


表 7-1 ScriptManager 控件 的 属性 及 说 明 
说 明 


AllowCustomErrorsRedirect 


在 异步 PostBack 情况 下 , 若 有 错误 发 生 ,指示 系统 是 否 引 发 自 定 义 错误 
的 网 页 导向 


AsyncPostBackErrorMessage 


当 服 务 器 有 异常 错误 发 生 , 此 错误 信息 会 被 送 到 Client 端 


AsyncPostBackTimeout 


异步 PostBack 的 Timeout 逾 时 的 时 间 长 度 ( 秒 ) , 预 设 是 90 秒 , 若 设置 为 
0, 则 表示 没有 Timeout 的 限制 


AuthenticationService 


获取 目前 ScriptManager instance 的 AuthenticationService-Manager 对 象 


EnablePageMethods 


设置 ASP .NET 的 静态 方法 是 否 能 够 被 Client 端 Script 调用 


EnablePartialRendering 


是 否 启用 局 部 更 新 


EnableScriptGlobalization 是 否 启 用 全 球 化 Script 设置 
EnableScriptLocalization 是 否 启用 区 域 化 Script 设置 
LoadScriptBeforeUI 设置 Script 参照 是 否 在 UI 控 件 之 前 加 载 到 Browser 浏览 器 中 


ProfileService 获取 目前 ScriptManager instance 的 ProfileServiceManager 对 象 
е 决定 在 生成 Client Script 时 ,要 产生 Debug 或 Release 版 本 的 Client 
ScriptMode un 
Script Libraries 
ScriptPath 指定 定制 的 Script 所 在 路 径 
Scripts 指定 ScriptManager 要 注册 的 Script 参照 集合 
Services 指定 ScriptManager 要 注册 的 Service 参照 集合 


ScriptManager 控件 负责 管理 AJAX 页 面 的 客户 端 脚本 。 默 认 情况 下 ,ScriptManager 控 
件 向 客户 端 发 送 AJAX 所 需 脚 本 ,这 样 客户 端 就 可 以 使 用 АТАХ 的 类 型 进行 系统 扩展 ,并 在 
服务 器 和 客户 机 之 间 来 回 编组 信息 ,完成 部 分 页 面 的 更 新 。SeriptManager 控件 的 HTML 代 


人 码 如 下 : 


<asp:ScriptManager ID ="ЅсгіріМапасегі" гопа ="server" > 


</asp:ScriptManager > 
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在 AJAX 应 用 中 ,ScriptManager 控件 基本 不 需要 配置 就 能 够 使 用 。 当 在 页 面 上 放置 了 
ScriptManager 控件 后 , 它 就 会 负责 加 载 ASP . NET. AJAX 需要 的 JavaScript 库 。 在 浏览 器 中 
运行 图 7-5 添加 了 ScriptManager 控件 的 defaul. aspx 页 面 , 右 击 , 从 弹出 的 快捷 菜单 中 选择 
“查看 源 " 命 令 , 可 以 看 到 多 个 如 下 的 脚本 代码 : 


< script src -"/dwi] _ 1lAkkhescuroe. axi? d = HISl0et8 UKHXYPLSZA5FEZilMfB51T7 
HAYJUBguHZnLSVOTFL352:KTCtpiBIRg79To ЕхО9рРђсй BysD9LrRCNODAWKOsEDPREL О sanp; t =635362220352906250" 
type ="text /javascript" > </script > 
当 页 面 中 添加 了 ScriptManager 控件 后 ,原文 件 中 增加 了 多 个 < script > 块 ,这 些 代 码 块 的 
作用 是 请 求 AJAX 的 客户 端 脚 本 ,通常 是 MicroSoftAjax. js 和 MicroSoftAjaxWebForm. js 文件 ， 
这 两 个 文件 被 通 入 到 System. Web. Extensions. dll 资源 文件 中 。 
6. 更 新 区 域 控件 ( UpdatePanel) 
UpdatePanel 服务 器 控件 是 ASP . NET AJAX 中 最 常用 的 控件 ,允许 执行 页 面 的 局 部 刷 
新 ,页 面 中 所 使 用 的 AJAX 控件 必须 放 在 UpdatePanel 控件 中 才能 发 挥 其 作用 。UpdatePanel 
相当 于 AJAX 控件 的 舞台 ,没有 了 UpdatePanel, AJAX 便 无 法 翩翩 起 舞 发 挥 作用 。 换 而 言 
之 ,ASP . NET 的 控件 只 有 放 在 UpdatePanel 中 才能 成 为 AJAX 控件 ,否则 实现 不 了 任何 
AJAX 功能 。 
UpdatePanel 控件 常用 属性 及 说 明 如 表 7-2 所 示 。 


表 7-2 UpdatePanel 控件 属性 及 说 明 
名 K 说 — H 
ChildrenAsTriggers 获取 或 设置 一 个 Boolean 类 型 的 值 ,指示 子 控件 是 否 自动 触发 异步 回 传 


获取 UpdatePanel 控件 ContentTemplate 的 容器 。 可 以 使 用 该 属性 以 编程 方式 
向 ContentTemplate 中 添加 控件 


IsInParrialRendering 获取 一 个 Boolean 类 型 的 值 ,指示 UpdatePanel 是 否 呈 现 以 响应 异步 回 传 


获取 或 设置 一 个 值 , 该 值 指 示 UpdatePanel 的 内 容 是 否 包 含 在 HTML < div > 或 
< span > 标签 中 。 可 能 的 值 为 Block( 默 认 ) 和 Inline 


Triggers 获取 触发 UpdatePanel 执行 异步 或 同步 回 传 的 控件 列表 


获取 或 设置 一 个 值 ,该 值 指示 何 时 更 新 UpdatePanel 中 的 内 容 。 可 能 的 值 为 
Always( 默认 ) 和 Conditional 


ContentTempContainer 


RenderMode 


UpdateMode 


UpdatePanel 控件 也 支持 Update( ) 方 法 ,使 UpdatePanel 更 新 其 内 容 。 

UpdatePanel 控件 要 进行 动态 更 新 ,必须 依赖 ScriptManager 控件 。 当 ScriptManager 控件 
允许 局 部 更 新 时 , 它 就 会 以 异步 的 方式 发 送 到 服务 器 。 服 务 器 接受 请 求 后 ,执行 操作 并 通过 
DOM 对 象 来 替换 局 部 代码 。 UpdatePanel 控件 通过 < ContentTemplate > 和 < Triggers > 标签 
来 处 理 页 面 上 引发 异步 页 面 回 送 的 控件 。 

当 首 次 呈现 包含 一 个 或 多 个 UpdatePanel 控件 的 页 面 时 ,将 呈现 UpdatePanel 控件 的 所 
有 内 容 并 将 这 些 内 容 发 送 到 浏览 器 。 在 后 续 异 步 回 发 中 ,可 能 会 更 新 各 个 UpdatePanel 控件 
的 内 容 。 更 新 将 与 面板 设置 .导致 回 发 的 元 素 以 及 特定 于 每 个 面板 的 代码 有 关 。 
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【任务 实施 】 
第 1 步 打开 Visual Studio 2010 开发 环境 ,新 建 一 


个 空 网 站 ,将 其 命名 为 cha7_1 ,添加 


一 个 Visual C# 的 Web 窗 体 ,名 称 为 Default. aspx ,并 设置 为 起 始 页 


第 2 步 ”在 Default. aspx 页 中 添加 一 个 ScriptManager 
控件 ,如 图 7-5 所 示 。 选 中 apium 控件 , 右 击 ,从 弹 
出 的 快捷 菜单 中 选择 “属性 "命令 ,可 以 查看 ScriptManager 
控件 所 包含 的 属性 ,如 图 7-6 所 示 。 

第 3 步 ” 在 Default. aspx 页 中 添加 一 个 UpdatePanel 
控件 ,如 图 7-7 所 示 。 选 中 UpdatePanel 控件 , 右 击 ,从 弹出 
的 快捷 菜单 中 选择 “属性 ”命令 ,可 以 查看 UpdatePanel 控 
件 所 包含 的 属性 ,如 图 7-8 所 示 。 

第 4 步 ТЕ UpdatePanel 控件 中 分 别 添加 一 个 Label 
控件 和 一 个 Button 控件 ,界面 设计 如 图 7-9 所 示 。 

第 5 步 ” 以 源码 的 方式 查看 Default. aspx 页 面 ,其 代 
ИШТ: 


«asp:UpdatePanel ID -"UpdatePanell" runat = 
"server" > 
«Content'Template > 
Xasp:Label ID -"Tabell" runat -"server" 
Text —"Label" > «/asp:label > 
<br /> 
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Scriptllanagerl System. Web UI ScriptManag > 


Si: Ta ERES 
an 


Scriptllanagc ^ 


AjsxFraneworkilode Enabled 
AllowCustomErrorsRedirect True 
AsyncPostBackErrorllessage 
AsyncPostBackTineout. 90 

E] Authenti cati onService 
Cli entIDllode Inherit 
ClientNavi gateHandl er 

Conposi teScript. 
EnptyPagelrl 
EnableCdn False 
Enableistory False 
EnablePagellethods False 


EnsblePartialRendering True 
EnsbleScriptGlobslization False 
EnableScriptLocalization True 
EnsbleSecureHistoryState True 


EnableVi evState True 

LoadScriptsBeforeUI True 
HEURE ——g 
Scripts 


EA CIC E TUM a 
EE UBL 控件 上 的 脚 


图 7-6 ScriptManager 控件 属性 


«asp:Button ID -"Button]" runat -"server" onclick -"Buttenl Click" 


Text "Button" /> 
«/Content Template > 
«/asp:UpdateParel > 


ME Default. aspx* x 


田 数据 UpdatePanell System Web. UI UpdatePanel — 
田 验证 B E 
国 导航 asprupdetepanels Updasbenei| Н mo- s= 
азж we à Ж 5 (Expressions) 
困 WebParts an) VpdatePanell 
АТАХ Extensions ChildrenhsTriggers True 
k 指针 ClientIDMode Inherit 
D] ѕегірналасег EnableVi exState True 
E  ScriptlanagerProxy Benderlods rd 
Triggers RE) 
Q Timer Updatellode Always 
Б] UpdatePanel ViewStatellode Inherit 
d) UpdateProgress Visible True 
[四 动态 数 据 


图 7-7 添加 UpdatePanel 控件 


图 7-8 UpdatePanel 控件 属性 


可 更 改 Label 控件 和 Button 控件 的 ID 值 以 便于 记忆 使 用 ,更 改 其 Text 值 可 显示 不 同 的 
内 容 。 本 例 为 显示 当前 时 间 , 所 以 将 Label 控件 的 ID 值 更 改 为 bTime,Button 控件 的 ID fH 


更 改 为 btTime ,Text 显示 为 当前 时 间 ,修改 后 代码 如 下 : 
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汪 BuleteaList 


Button 控 件 


WE Calendar 


CheckBox 


在 updatepanel 控 件 中 添加 
Label 控 件 和 Button 控 件 


外 FileUpload 
ii HiddenField 
A HyperLink 
国 Inage 

(8) InageButton 
lli] Imagettap 


图 7-9 在 UpdatePanel 控件 中 添加 Label 和 Button 控件 


«asp:UpdatePanel ID ="UpdatePanell" runat ="server" > 
«ContentTemplate > 
«asp:label ID ="]bime" runat "server" Text "Label" > </asp:Tabel > 
<br /> 
«asp:Button ID -"btTime" runat -"server" onclick -"btTime Click" Text = 
"当前 时 间 " /> 
</ContentTerplate > 
</asp:UpdatePanel > 
第 6 步 ”双击 放置 在 UpdatePanel 控件 中 的 Button 按钮 ,触发 其 Click 事件 ,获取 当前 系 
统 时 间 ,代码 如 下 : 
protected void btTime Click(doject sender, EventArgs e) 
t 
this. lbTime. Text -DateTime.Now. ToString () ; 
) 
第 7 步 在 浏览 器 中 查看 Default. aspx 页 面 ,其 运行 效果 如 网 7-10 所 示 。 
第 8 步 ”新建 一 个 网 站 ,命名 为 cha7_1_1 ,在 Default. aspx 页 面 中 直接 添加 Label 控件 
和 Button 控件 ,并 设置 Button 按钮 控制 Label 控件 显示 当前 时 间 , 即 将 Label 控件 和 Button 
控件 移 到 UpdatePanel 控件 之 外 ,然后 浏览 网 页 单 击 执行 显示 “当前 时 间 " 按 钮 ,与 cha7_1 运 
行 结 果 对 比 ,效果 如 图 7-11 所 示 。 
由 图 7-11 可 以 看 出 ,使 用 AJAX 技术 ,在 UpdatePanel 控件 中 的 内 容 实 现 了 无 刷新 界面 ， 
无 进度 条 ,未 出 现 “ 闪 屏 ” ,而 未 使 用 AJAX 技术 的 页 面 , 与 服务 器 交互 获取 数据 信息 ,整个 页 
面 刷新 ,会 出 现 “ 闪 屏 ”。 
【任务 小 结 】 
本 任务 对 AJAX 技术 进行 简单 介绍 ,并 说 明了 其 优势 与 应 用 。 介 绍 了 AJAX 技术 中 党 
用 的 控件 ScriptManager 控件 和 UpdatePanel 控件 ,并 对 其 进行 实例 应 用 ,说 明 AJAX 技术 在 
不 刷新 整个 页 面 的 情况 下 对 部 分 数据 进行 更 新 。 
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ARER gs 
|E http://ocslhost:19... | | Ë 7 с @- O- RLO 


2014-6-23 192948 


当前 时 间 


点 击 当前 时 间 Button 获 取 当 前 时 间 


图 7-10 在 UpdatePanel 控件 中 无 刷新 显示 当前 时 间 


(6 http://localhost / http://localhost:1971/chaT | [a] [E23| 


GO- [e BIB] (x) [Bas с IE] 
XEO RED 查看 | LFO RED FEV wQ) IAV WHW 
ўж |4 жах | 次 
IT J[éussnemens. | | m + 9 c ж - лш. #т®- 


2014-6-23 19:06:48 | 2014-6-23 192032 


Label 和 Button Label 和 Button 控 件 在 UpdatePanel 控 件 内 
控件 在 
UpdatePanel 控 


图 7-11 第 一 个 Windows 窗 体 应 用 程序 执行 效果 


【拓展 提高 】 

协调 两 个 UpdatePanel 控件 之 间 的 互动 。 

第 1 步 FIF Visual Studio 2010 开发 环境 ,新 建 一 个 网 站 ,将 其 命名 为 cha7_2 ,默认 主 
页 为 Default. aspx, fE Default. aspx 页 面 添加 一 个 ScriptManager 控件 和 两 个 UpdatePanel 控件 ， 
构建 AJAX 环境 。 

第 2 步 ” 在 第 一 个 UpdatePanel 控件 中 添加 两 个 
Label 控件 ,Text 属性 值 分 别 为 “姓名 :“、“ 性 别 : ”, 在 
两 个 Label 控件 后 分 别 添加 一 个 TextBox 控件 ,用 于 用 
户 输入 信息 ;然后 添加 两 个 Button 控件 ,一 个 用 来 添加 
信息 ,一 个 用 于 取消 输入 内 容 ; 最 后 再 添加 一 个 Label 图 7-12 UpdatePanel 用 于 输入 信息 
控件 , 读 取 添 加 内 容 时 的 当前 时 间 。 添 加 后 效果 如 
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图 7-12 所 示 。 
第 一 个 UpdatePanel 设计 代码 如 下 : 


<asp:UpdatePanel ID-"InsertEmloyeeUpcatePanel" runat ="server" Updatewpde = 
"Conditional" > 
<ContentTemplate > 
<asp:Iabel ID -"Label1" runat ="ѕегуег" Text ="#} |: "></asp:Iabel > 
<asp:TextBox runat ="зегуег" ID "tiae" /> 
<br/ > 
<asp:Iabel ID -"Tabel2" runat -'server" Text =]: " ></asp:Iabel > 
<asp:TextBox runat ="зегуег" ID = Ббех" /> 
<br/ > 
«asp:Button ID -"InsertButton" runat -"server" Text "K Jill" Click = 
"InsertButton Click > 
<asp:Button ID-"Cancelbutton" runat ="server" Text = 取消 " onclick= 
"CancelButton Click" /> 


<br/ > 
<asp:Label ропа -"server" ID -"IrputTimelLabel" > <% =ГабеТіпе.М№он% > 
X/asp:label > 
asp:UpdatePanelSUpdatePane? 
</ContentTenplate > 
«/asp:UpdateParel > RERE HERE 


数据 绑 定 HERE 


第 3 步 。 在 第 二 个 UpdatePanel 控件 中 放置 一 个 “| | ЖЕЛЕ suse 
GridView 控件 ,用 于 绑 定 用 户 信息 ,显示 原 数据 和 新 添 || mee mE 
加 数据 ;然后 在 GridView 控件 下 方 添加 一 个 Label 控件 ， 
用 于 显示 更 新 后 数据 的 当前 时 间 , 如 图 7-13 所 示 。 

第 二 个 UpdatePanel 设计 代码 如 下 : 


图 7-13 UpdatePanel 用 于 显示 信息 


«asp:UpdatePanel ID —"UpdatePanel2" runat "server" > 
<ContentTenplate > 
<asp:GridView ID -"GVErployees" runat -"server" BackColor = 
"LightGoldenrodYel low" 
BorderColor ="Тап" BorderWidth -"1px" CellPadding ="2" ForeColor = 
"Black" 

GridLines ="Мопе" AutcGenerateColums -"False" Width ="272px" > 

«FooterStyle BackColor ="Тап" / > 

«SelectedRowStyle BackColor -"DarkSlateBlue" ForeColor = 

"Ghostyhite" /> 

XPagerStyle BackColor 一 FaleGoldenrod" ForeColor -"DarkSlateBlue" 
HorizontalAlign —"Center" /> 

«HeaderStyle BackColor ="Тап" Font -Bold "True" /> 

<AltematingRowStyle BackColor =" denrod" / > 

«Colums > 
«asp:BoundField DataField -"EmloyeeID" HeaderText 一 员工 号 "> 
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<TtenStyle HorizontalAlign -"Center" /> 
</asp:BoundField > 
«asp:BoundField DataField -"Name" HeaderText =й" /> 
«asp:BourdField DataField ="Sex" HeaderText 一 性 别 " /> 
«/Colums > 
<EagerSettings PageButtonCount ="8" / > 
«/asp:GridView > 
«asp:label runat server" ID-"ListTimelabel" ><% -DateTime.Nows > 
«/asp:label > 
</ContentTerplate > 
«Triggers > 
«asp:AsyncPostBackTrigger Control ID ="InsertButtcn" EventN=me -"Click" /> 
</Triggers > 
«/asp:UpdateParel > 
第 4 步 ” 在 默认 主页 面 的 后 台 代码 Page_load 事件 中 ,首先 实例 化 List < T > 类 对 象 , 并 
初始 化 2 个 值 用 于 绑 定 GridView 控件 中 的 数据 。 代 码 如 下 : 


protected void Page Ioad(doject sender, EventArgs e) 


{ 
if (!IsPostBack) 
{ 
enpList =new List <Ehployee >(); 
aplist.Adi (nes Employee (L, "К<", "9 ")); 
aplist.Adi (new Eployee (2, "0", "40")); 
ViewState ["enpiList"] =enpList; 
) 
else ( 
aplist =(List <hployse >) (ViewState ["apList"]) ; 
} 
GVEhployees.DataScurce =erplist; 
GEhployees.DataBind () ; 
} 


第 5 步 KRR HG" AY On_Click 事件 ,实例 运行 效果 如 图 7-14 所 示 。 
http: //localhost:3458/chsT 2/Default. aspx 


输入 信息 
图 7-14 ”实时 更 新 两 个 UpdatePanel 控件 中 的 内 容 
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任务 7-2 使 用 Timer 控件 


【任务 描述 】 

小 王 正 在 开发 的 项 目 中 遇 到 一 个 特定 需求 : 每 天 晚上 把 业务 数据 以 邮件 的 方式 发 送 给 
业务 人 员 ,以 便 第 二 天 业务 人 员 可 以 参考 业务 数据 。 这 要 求 系统 提供 周期 性 定时 功能 ,还 好 
小 王 对 ASP .NET 的 Timer 控件 是 有 所 了 解 的 。 


【任务 目的 】 

(1) 了 解 Timer 控件 。 

(2) 掌握 Timer 控件 的 简单 应 用 。 

【任务 分 析 】 

在 访问 网 站 时 ,通常 会 看 到 页 面 上 有 一 个 时 钟 ,用 来 显示 系统 当前 的 时 间 。 这 通常 是 通 
过 JavaScript 脚本 程序 来 实现 的 ,同样 ,我 们 可 以 使 用 AJAX 控件 Timer 来 实现 站 点 时 钟 
显示 。 

【基础 知识 】 

定时 控件 (Timer) 的 使 用 方法 如 下 。 

在 应 用 UpdatePanel 控件 实现 页 面 局 部 更 新 时 ,用 户 必须 初始 化 一 个 一 般 情况 下 会 回 发 
的 动作 ,如 单 击 按钮 。 但 在 实际 应 用 中 ,用 户 可 能 会 希望 没有 动作 的 情况 下 自动 完成 一 次 完 
整 或 局 部 页 面 的 刷新 ,此 时 便 可 利用 AJAX 的 Timer 控件 ,每 隔 一 段 时 间 固 定 触发 一 个 事 
件 ,Timer 控件 让 刷新 UpdatePanel( 或 整 页 ) 有 了 时 间 上 的 依据 。 

Timer 控件 若 没有 与 UpdatePanel 控件 关联 ,那么 Timer 将 执行 普通 的 回 传 ,把 整 页 回 传 
到 服务 器。Timer 控件 更 经 典 的 应 用 是 与 UpdatePanel 控件 相关 联 , 实现 定时 刷新 
UpdatePanel 控件 的 内 容 。 

Timer 控件 能 够 在 一 定时 间 间 隔 内 触发 某 个 事件 ,其 对 应 的 HTML 代码 如 下 : 

<asp:Timer ID -"Timer1" runat ="зегуег" > 

</азр:Тілег > 

Timer 控件 常用 的 属性 及 说 明 如 表 7-3 所 示 。 

表 7-3 Timer 控件 属性 及 说 明 
名 Ж 说 — HJ 
Interval 时 间 间 隔 设置 ,单位 为 ms, 其 中 设置 为 1000 时 表示 1s 的 时 间 间 隔 

Timer 是 否 可 用 , 即 Timer 是 否 启动 , 设 为 true 时 Timer 开始 工作 , 设 为 false 时 Timer 停止 
工作 
Tick 事件 “| 直接 在 Timer 控件 上 双击 ,可 添加 Tick 事件 程序 


Enabled 


Timer 控件 是 一 个 服务 器 控件 , 它 会 将 一 个 JavaScript 组 件 嵌 入 到 网 页 中 。 当 经 过 
Interval 属性 中 定义 的 时 间 间 隔 时 ,该 JavaScript 组 件 将 从 浏览 器 启动 回 发 。 可 以 在 运行 与 
服务 器 上 的 代码 中 设置 Timer 控件 的 属性 ,这 些 属性 将 传递 给 该 JavaScript 组 件 。 

使 用 Timer 控件 时 ,必须 在 网 页 中 包含 ScriptManager 类 的 实例 。 若 回 发 是 由 Timer J 
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件 启动 的 , 则 Timer 控件 将 在 服务 器 上 引发 Tick 事件 。 当 页 面 发 送 到 服务 器 时 ,可 以 创建 
Tick 事件 的 处 理 程序 来 执行 一 些 操作 。 

WE Interval 属性 可 指定 回 发 的 频率 ,而 设置 Enabled 属性 可 打开 或 关闭 Timer 控件 。 
Interval 属性 是 以 ms 为 单位 定义 的 ,其 默认 值 为 60000ms( 即 60s) 。 

必须 说 明 的 是 ,Timer 控件 可 能 会 加 大 Web 应 用 程序 的 负载 。 因 此 ,在 引入 自动 回 发 特 
性 前 并 在 确实 需要 时 引入 Timer 控件 ,并 尽 可 能 把 间隔 时 间 设 置 得 长 一 点 ,如 果 设 置 得 太 短 
将 会 使 得 页 面 回 发 频率 增加 ,加 大 服务 器 的 流量 。 

【任务 实施 】 

第 1 步 。 打开 Visual Studio 2010 开发 环境 ,新 建 一 个 空 网 站 ,将 其 命名 为 cha7_3 ,添加 
一 个 Visual C# 的 Web 窗 体 ,名 称 为 Default. aspx ,并 设置 为 起 始 页 。 

第 2 步 构建 AJAX 环境 。 在 Default. aspx 页 中 添加 一 个 ScriptManager 控件 进行 页 面 
全 局 管理 ;添加 一 个 UpdatePanel 控件 ,实现 时 钟 的 局 部 更 新 。 

第 3 2 ”在 UpdatePanel 控件 中 添加 一 个 Label 控件 。Label 控件 用 于 显示 时 间 。 

第 4 步 在 UpdatePanel 控件 中 添加 一 个 Timer 控件 如 图 7-15 所 示 。 将 Timer 控件 的 
interval 属性 设置 为 1000 , 即 间隔 时 间 为 1s,Enabled 设置 为 True ,如 图 7-16 所 示 。 


Default. aspx X 


Timerl System. Web. UI. Timer 
fasp:updatepanelzUpdatePaneli] 


注意 : Timer 控 件 在 
UpdatePanel 控 件 里 


图 7-15 添加 Timer 控件 图 7-16 设置 Timer 控件 属性 
其 页 面 中 核心 代码 如 下 : 


«asp:ScriptManager ID -"ScriptManagerl" runat -"server" > 
«/asp:ScriptManager > 
«asp:UpdatePanel ID -"UpdatePanell" runat -"server" > 
«Ccntent Template > 
«asp:label ID ="Labe1l1" runat -"server" Text -"Label" > «/asp:label > 
«asp:Timer ID ="Тіпегі" runat -"server" Interval ="1000" cntick = 
"Timerl Tick" > 
«/asp:Timer > 
«/Content Template > 
«/asp:UpdatePanel > 


第 5 步 ” 双击 Timer 控件 ,在 Timerl. Tick 事件 中 添加 获取 当前 时 间 的 代码 ,事件 代码 
WP: 
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protected void Timerl Tick (cbject sender, EventArgs е) 
{ 

Iabell .Text =DateTime.Now.ToString () ; 
} 


第 6 步 ” 在 浏览 器 中 查看 页 面 , 当 页 面 加 载 时 ,在 Labell 控件 中 显示 设置 得 默认 值 
Label , Timer 控件 用 于 每 隔 一 秒 进行 一 次 刷新 并 将 当前 时 间 显 示 在 Labell 控件 中 ,效果 如 图 
7-17 所 示 。 


(С 使 用 Timer 控 件 显示 1 /3 使 用 Tiaez 控 件 显 志 (2 Tineri ERIH — Windows Interne... [- [PX] 
Go- http htt Е) sese... BE [n] [x] [a Live serc 


文件 四 dp 查看 | LD SEO mj 文件 四 Gc) SEV шло тат HHW 


wj 2 елтнтн | | m - m oce 


2014-6-24 1:42:15 


时 间 继 续 运 行 


Q Internet 


图 7-17 使 用 Timer 控件 显示 时 钟 


第 7 步 ” 将 Timer 控件 移 至 UpdatePanel 控件 
外 ,其 设计 视图 如 图 7-18 所 示 。 
其 页 面 中 核心 代码 如 下 : 


<asp:ScriptManager ID -"ScriptManagerl" runat -"server" 
> 
</asp:ScriptManager > 
< азр: UpdatePanel ID -"UpdatePanell" runat =" 17-18 Timer 控 件 移 至 UpdatePanel 
VIA 控件 外 
«Content Template > 
«asp:Label ID -"Labell" runat -"server" Text -"Tabel" > «/asp:Label > 
«/Gontent Template > 
«/asp:UpdatePanel > 
<br /><br /> 


<asp:Timer 1 ="Тіпегі" runat -"server" Interval ="1000" ontick-"Timerl Tick" > 
«/asp:Timer > 
其 他 的 设置 代码 不 变 。 
第 8 步 ” 在 浏览 器 中 查看 页 面 , 当 页 面 加 载 时 ,在 Labell 控件 中 显示 设置 得 默认 值 
Label, j fE Timer 控件 在 UpdatePanel 控件 中 相同 。 但 Timer 控件 每 隔 一 秒 进行 一 次 刷新 
时 ,刷新 为 整体 页 面 ,出 现 进度 条 ,效果 如 图 7-19 所 示 。 


Timer 控件 没有 与 UpdatePanel 控件 关联 ,Timer 执行 普通 的 回 传 ,把 整 页 回 传 到 服务 器 ， 
产生 整个 页 面 刷新 ,页 面 刷 新 时 出 现 进度 条 。 


由 图 7-17 与 图 7-19 可 以 看 出 ,Timer 控件 的 摆 放 位 置 对 于 AJAX 的 应 用 有 影响 。Timer 
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/使 用 Timer 控 件 显示 时 神 — Windows Internet Explorer 加 回国 | 


GO- 2л. BE] [x] [facies serc 
XFO #80 SEV KERO ТАФ Wb 
авах | ¿s 


Bem SERE | | Q + 9 oc Br mo: 


2014-6-24 2:00:39 


图 7-19 在 UpdatePanel 控件 中 无 刷新 显示 当前 时 间 


摆 放 位 置 是 相对 于 UpdatePanel 控件 而 言 的 ,如 果 Timer 控件 位 于 UpdatePanel 之 外 ,可 以 为 
UpdatePanel 的 Triggers 属性 明确 定义 一 个 由 Timer 控件 的 Tick 事件 所 引发 的 触发 器 。 
【任务 小 结 】 
本 任务 介绍 了 AJAX 技术 中 常用 的 Timer 控件 ,对 其 进行 实例 应 用 ,并 指出 Timer 控件 
的 位 置 影响 页 面 的 刷新 。 
【拓展 提高 】 
实现 在 线 考 试 倒 计时 。 
第 1 步 FTF Visual Studio 2010 开发 环境 ,新 建 一 个 网 站 ,将 其 命名 为 cha7_4 ,默认 主页 
为 Default. aspx, 在 Default. aspx 页 面 添加 一 个 ScriptManager 控件 和 一 个 UpdatePanel 控件 ， 
构建 AJAX 环境 。 — nn 
第 2 步 在 UpdatePanel 控件 中 添加 一 个 Label 控件 ， Pa ist ss х 
用 来 提示 考试 剩余 时 间 。 再 添加 一 个 Timer 控件 ,用 来 控 | seiten - Scripttanaceri 
制 倒计时 ,并 将 Timer 控件 的 interval 属性 设置 为 1000, 即 [е 
间隔 时 间 为 1s, Enabled 设置 为 True。 添 加 后 效果 如 
图 7-20 所 示 。 
其 页 面 中 核心 代码 如 下 : 


«asp:ScriptManager ID -"ScriptManagerl" runat -"server" > 
</asp:ScriptManager > 
<asp:UpdatePanel ID -"UpdatePanell" runat ="server" > 
<ContentTerplate > 
<asp:labe1 ID -"Labell" runat ="server" Text ="Таре1" > «/asp:label > 
«asp:Timer ID-"Timer1" nmt "server" Interval ="1000" ontick-"Timerl Tick" > 
</азр:Тіпег > 
«/Content Template > 
«/asp:UpdateParel » 


第 3 步 ” 双 击 Timer 控件 ,在 Timerl_Tick 事件 中 添加 获取 当前 时 间 的 代码 ,事件 代码 
WP: 


图 7-20 考试 倒计时 页 面 设计 
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protected void Timerl Tick (cbject sender, EventArgs e) 
{ 
this.RemainingTime — —; 
if (this.Remininglime ==0) // 考 试 时 间 到 
{ 
this.Iabell.Text "时 间 到 "; 
this.Timerl .Enabled=false;  // 设 置 Timer 控 件 不 可 见 
// 自 动 交 卷 功能 实现 


// 显 示 考 试 剩余 时 间 
this.Iabell1.Text= 仅 剩 "+this.RarainingTimey/60 + 分 " 4this.RemainingTime 
560 +" 秒 ,请 及 时 交卷 ,否则 试卷 作废 ,成 绩 无 效 1n 


) 


其 中 RemainingTime 是 一 个 自 定 义 整数 类 型 变量 ,用 来 设置 当前 考试 时 间 进 入 最 后 10 Ж 
(为 看 效果 ) 时 给 予 倒计时 提示 。 代 码 如 下 : 

/// <sumary> 

/// 定义 在 线 考 试 总 时 间 变 量 RerainingTime 

/// 设 定 10 秒 为 看 效果 ) 

/// «/smmary > 

private int RemainingTime 

{ 


get 
t 


dbject o -ViewState ["RerainingTime "]; 
retum (o --null) ? 10 : (int)o; 


ViewState ["RemaeiningTime "] —alue; 


第 4 步 ”在 浏览 器 中 查看 页 面 , 当 页 面 加 载 时 ,在 Labell 控件 中 显示 设置 的 默认 值 
Label ,Timer 控件 用 于 每 隔 一 秒 进 行 一 次 刷新 并 将 倒计时 信息 显示 在 Labell 控件 中 ,直到 倒 
计时 结束 ,Timer 控件 停止 工作 ,不 再 回 传 。 效 果 如 图 7-21 所 示 。 


任务 7-3 使 用 AJAX Control Toolkit 扩展 控件 工具 包 

【任务 描述 】 

小 王 项 目 提交 过 后 ,在 试 运行 期 间 ,功能 问题 几乎 没有 ,但 是 用 户 体验 却 很 差 ,发 现 很 多 
问题 : 日 期 输入 不 方便 修改 密码 事前 没有 提醒 却 不 能 修改 提示 不 友好 等 。 为 了 提升 用 户 
体验 ,小 王 只 好 使 用 ASP . NET 的 AJAX 扩展 包 了 。 
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图 7-21 在 线 考试 倒计时 实现 效果 
【任务 目的 】 


(1) 了 解 AJAX Control Toolkit 扩展 控件 工具 包 。 
(2) 掌握 AJAX Control Toolkit 扩展 控件 工具 包 的 简单 应 用 。 
【任务 分 析 】 
浏览 网 页 时 ,可 以 在 弹出 的 日 历 图 标 上 选择 想 输 入 的 年 月 日 ;注册 用 户 信息 时 会 填写 密 
码 , 页 面 会 提示 密码 的 强度 等 友好 的 提示 ,这 些 方便 快捷 的 操作 ,有 着 良好 的 用 户 体验 ,也 可 
以 通过 AJAX Control Toolkit 扩展 控件 工具 包 来 实现 这 些 功 能 。 
【基础 知识 】 
1. AJAX Control Toolkit 简介 
ASP .NET AJAX Control Toolkit( 控件 工具 包 ) 是 基于 ASP . NET AJAX 基础 之 上 构建 
的 ,提供 了 五 十 多 种 服务 器 端 AJAX 控件 ,可 以 在 ASP . NET 应 用 中 使 用 ,可 以 用 它们 创建 
网 站 特效 ,如 动画 、 贺 角 和 模 态 弹 出 窗口 ,还 可 用 在 更 实际 的 应 用 中 ,如 实现 自动 完成 (auto- 
complete ) ЖЕҢ ( masked edit) АЖЕ ,并 且 它 是 微软 免费 提供 的 一 个 资源 ,能 轻松 创建 
客户 端 AJAX 功能 页 面 。 
ASP .NET AJAX Control Toolkit 中 的 控件 为 AJAX( 广 义 的 AJAX) 控 件 ,所 有 Toolkit 控 
件 都 使 用 客户 端 JavaSeript。 尽 管 如 此 ,大 多 数控 件 并 不 执行 异步 回 传 ,因此 , 称 它们 为 
AJAX 控件 是 因为 它们 使 用 了 大 量 的 JavaScript。 
几乎 所 有 Toolkit 中 的 控件 都 是 扩展 器 控件 ( Extender Control) 。 这 些 控 件 扩展 已 有 的 
ASP .NET 控件 (如 标准 TextBox 和 Panel 控件 ) 以 实现 新 的 功 


能 。 几 乎 所 有 的 Toolkit 控件 都 包含 TargetControlID 属性 ,用 来 талан 1 
指向 所 扩展 的 控件 。 下 面 介绍 几 个 常用 的 Toolkit 控件 。 Mo Tu We Th Fr sa su 
2. 日 历 控 件 ( CanlendarExtender ) Р 
CanlendarExtender 即日 历 控件 ,是 用 来 输入 日 期 的 。 该 探 олоо m m 
件 会 在 TextBox 控件 旁边 弹出 一 个 日 历 , 单 击 弹出 日 历 上 的 日 a 
期 可 以 选择 年 月 .日 , 单 击 某 一 天 后 ,日 期 会 自动 被 设置 在 文 99: June 24, 2014 
TEE ,其 效果 如 图 722 Biss. 图 7-22  CanlendarExtender 
CanlendarExtender 控件 的 属性 及 说 明 如 表 74 所 示 。 | 


控件 效果 
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表 7-4  CanlendarExtender 控件 属性 及 说 明 


名 Ж 说 B 
TargetControlID 所 要 实现 日 历 功能 的 文本 框 了 D ,如 TargetControlID = "TextBoxl" 
Format 所 要 显示 的 日 期 格式 ,如 Format ="yyyy 年 MM 月 dd 日 " 
PopupButtonID 控制 日 历 弹出 窗 的 控件 也 ,如 果 留 空 则 当 文 本 框 获得 焦点 时 弹出 
PopupPosition 弹出 的 位 置 ,默认 为 文本 框 的 左下 方 
SelectdDate 当前 所 选择 的 日 期 
FirstDayOfWeek 一 周 的 第 一 天 为 星期 几 , 如 FirstDayOfWeek ="Monday" 


只 要 把 CanlendarExtender 控件 拖 忠 到 要 实现 自动 完成 的 文本 框 上 即 可 使 用 ,也 可 以 根 
据 实际 情况 设置 Format .PopupButtonID 和 PopupPostion 等 属性 。 

3. 密码 强度 控件 (PasswordStrength ) 

密码 强度 是 保护 个 人 信息 的 第 一 道 防线 ,用 户 设置 密码 时 智能 提示 用 户 所 输入 的 密码 
安全 级 别 有 利于 用 户 设 定安 全 级 别 较 高 的 密码 ,保护 个 人 信息 。ASP . NET AJAX Control 
Toolkit 提供 了 附加 在 TextBox 控件 的 一 个 密码 强度 控件 PasswordStrength , 当 用 户 在 密码 框 
中 输入 密码 时 ,文本 框 的 后 面 会 有 一 个 密码 强度 提示 ,这 种 提示 有 两 种 方式 : 文本 信息 和 图 
形 化 的 进度 条 。 另 外 , 当 密 码 框 失 去 焦点 时 提示 信息 会 自动 消失 。 

PasswordStrength 控件 的 常用 属性 及 说 明 如 表 7-5 所 示 。 

表 7-5 PasswordStrength 控件 属性 及 说 明 
名 称 说 — HH 

要 检测 密码 的 TextBox 控件 ID ,例如 : 


TetgetGontell D TargetControlID = " TextBox1" 
š ВА 密码 强度 提示 的 信息 的 位 置 ,例如 : 
DisplayPosition 


DisplayPosition = " RightSide | LeftSide | BelowLeft " 
密码 强度 信息 提示 方式 ,包括 文本 和 进度 条 ,例如 : 


StrengthIndicatorType = " Text | BarIndicator" 


StrengthIndicatorType 


PreferredPasswordLength 密码 的 长 度 
Bhat 用 文本 方式 时 开头 的 文字 ,例如 : 

PrefixText = " 密码 强度 :" 
TextCssClass 用 文本 方式 时 文字 的 CSS 样式 
MinimumNumericCharacters 密码 中 最 少 要 包含 的 数字 数量 
MinimumSymbolCharacters 密码 中 最 少 要 包含 的 符号 数量 ,例如 :" = ,#,@" 


RequiresUpperAndLowerCaseCharacters 是 否 需 要 区 分 大 小 写 


文本 方式 时 的 文字 提示 信息 ,例如 : 
TextStrengthDescriptions = " 极 弱 ; 弱 ;中 等 ; 强 ; 超 强 " 


TextStrengthDescriptions 


+ 209 ~ 


名 Ж 说 明 
BarIndicatorCssClass 进度 条 的 CSS 样式 
BarBorderCssClass 进度 条 边框 的 CSS 样式 
HelpStausLabelID 帮助 提示 信息 的 Lable 控件 ID 
密码 组 成 部 分 所 占 的 比重 ,其 值 的 格式 为 "A;B;C;D"。 其 中 
m A 表示 长 度 的 比重 ,B 表示 数字 的 比重 ,C 表示 大 写 的 比重 ,D 
CalculationWeightings 


表示 特殊 符号 的 比重 。A 、B、C.D 4 个 值 的 和 必须 为 100 ,默认 
值 为 50;15;15;20 


4. 自动 完成 控件 (AutoCompleteExtender) 

AutoCompleteExtender 控件 即 自动 完成 AJAX 控件 ,是 使 用 较 频 繁 的 控件 ,允许 将 标准 
的 ASP .NET TextBox 控件 转换 成 类 似 组 合 框 的 控件 ,其 主要 功能 在 向 TextBox 中 输入 文本 
时 ,控件 下 方 会 显示 一 个 匹配 输入 的 列表 ,帮助 用 户 在 输入 简单 的 字符 以 后 ,智能 感知 和 提 
示 。 这 些 功能 在 很 多 网 站 都 有 应 用 ,如 Google .百度 等 ,其 效果 如 图 7-3 所 示 。 

AutoCompleteExtender 控件 在 输入 数据 的 时 候 , 使 用 了 AJAX 调用 ,从 Web 服务 器 得 到 
匹配 的 选项 ,可 以 使 用 AutoCompleteExtender 控件 从 海量 数据 库 中 高 效 地 检索 数据 ,浏览 器 
永远 不 需要 下 载 整个 数据 库 项 。 

AutoCompleteExtender 在 客户 端 巧 妙 地 缓存 了 数据 , 当 向 TextBox 输入 以 前 输入 过 的 文 
本 时 ,AutoCompleteExtender 控件 会 从 缓存 中 找到 要 提示 的 内 容 , 而 不 需要 执行 男 一 个 AJAX 


调用 来 得 到 相同 的 信息 。 


AutoCompleteExtender 控件 的 常用 属性 及 说 明 如 表 7-6 所 示 。 


表 7-6 AutoCompleteExtender 控件 属性 及 说 明 


名 Ж 说 明 
ServicePath 指定 自动 完成 功能 Web Service 的 路 径 , 例 如 : 
A ServicePath = " AutoCompleteService. asmx" 
nn 指定 自动 完成 功能 Web Method 的 名 称 ,例如 : 
Tu ServiceMethod = " GetWordList " 
DropDownPanelID 指定 显示 列表 的 Panel 的 ID ,一 般 情 况 会 提供 一 个 默认 的 ,无需 指定 
Mimi 开始 提供 自动 完成 列表 的 文本 框 内 最 少 的 输入 字符 数量 ,例如 : 
imimumPrefixLength 


MimimumPrefixLength = " 1" 


AutoCompleteExtender 控件 提示 的 文本 数据 是 从 数据 库 中 读 取 的 。 

使 用 AutoCompleteExtender 15 件 的 方法 如 下 : 

(1) 从 左 侧 的 工具 箱 中 把 AutoCompleteExtender 控件 拖 电 到 要 实现 自动 完成 的 文本 框 
Lb. БАУ, AutoCompleteExtender 控件 会 自动 与 文本 框 关联 起 来 。 

(2) 向 网 站 项 目 中 添加 一 个 Web 服务 。 

(3) 编写 带 有 WebMethod 特性 的 获取 字符 串 数组 的 方法 ,其 返回 值 必须 为 string ] ,而 
参数 必须 为 string prefixText，int count。 
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(4) 为 Web 服务 类 添加 [System. Web. Script. Services. ScriptService ] 特性 。 
(5) 回 到 页 面 ,为 AutoCompleteExtender 控件 设置 属性 ,设置 ServicePath 为 Web 服务 的 
路 径 , 设 置 ServiceMethod 为 刚刚 编写 的 返回 字符 串 数组 的 方法 名 。 


【任务 实施 】 

1. 安装 AJAX Control Toolkit 扩展 控件 工具 包 

第 1 步 下 载 ASP .NET AJAX Control Toolkit ,地 址 是 http ;//ajaxcontroltoolkit. codeplex. 
com/( 这 里 以 下 载 AjaxControlToolkit. Binary. NET40. zip 为 例 )。 将 AjaxControlToolkit. Binary. 
NET40. zip 解压 缩 到 任意 位 置 ,其 中 包含 一 个 AjaxControlToolkit. dll 的 文件 。 

第 2 步 JAZ Visual Studio 2010, 打 开 “ 工 具 箱 "窗口 , 右 击 空白 处 ,弹出 图 7-23 所 示 的 
快捷 菜单 ,选择 “添加 选项 卡 "命令 ,在 “工具 箱 " 窗 口 出 现 新 添加 的 选项 卡 , 将 其 命名 为 Ajax 
Control Toolkit ,如 图 7-24 所 示 。 


GlAjax Control Tooli . 


Матан. т 入 


本 可 将 其 


重 命名 选项 卡 ER) 
tw 
TEW 


图 7-23 “添加 选项 卡 " 快 捷 菜 单 图 7-24 ”为 选项 卡 命名 


国 常 规 


第 3 步 ” 右 击 Ajax Control Toolkit 选项 卡 ,弹出 图 7-25 所 示 的 快捷 菜单 ,选择 “选择 项 ” 
命令 ,弹出 “选择 工具 箱 项 "对 话 框 ,如 图 7-26 所 示 。 
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图 7-25 添加 “选择 项 "快捷 菜单 


第 4 步 ” 在 “选择 工具 箱 项 "对 话 框 , 单 击 “ 浏 览 " 按 钮 ,查找 到 AjaxControlToolkit. dll 程 
序 集 , 然 后 单 击 “ 打 开 ” 按 钮 ,如 图 7-27 所 示 , 单 击 “ 选 择 工具 箱 项 "的 “确定 ”按钮 ,将 控件 添 
加 到 Visual Studio 2010 的 Ajax Control Toolkit 选项 卡 中 。 新 建 或 打开 一 个 网 站 ,添加 后 的 
Ajax Control Toolkit 选项 卡 如 图 7-28 所 示 。 
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对 象 名 称 凶 ;|AjaxControlToolkit 
HERH T): 可 执行 文件 (x. 411; * exe) 


图 7-27 添加 AjaxControlToolkit. dll 文件 


2. 使 用 CanlendarExtender 控件 

第 1 步 打开 Visual Studio 2010 开发 环境 ,新 建 一 个 空 网 站 ,将 其 命名 为 cha7_5 ,添加 
Visual C# 的 Web 窗 体 ,命名 为 Default. aspx ,并 设置 为 起 始 页 。 

第 2 步 WE AJAX 环境 。 在 Default. aspx 页 中 添加 一 个 ScriptManager 控件 进行 页 面 
全 局 管理 。 

第 3 步 ” 添 加 一 个 Label 控件 ,将 其 Text 属性 设置 为 "请 输入 一 个 日 期 ”, 用 于 提示 用 户 

第 4 步 ”添加 一 个 TextBox 控件 , 单 击 右 侧 的 按钮 ,如 图 7-29 所 示 , 单 击 “ 添 加 扩展 程 

2212: 


序 ”, 弹 出 “扩展 程序 向 导 ”, 如 图 7-30 所 示 。 选 择 CanlendarExtender, 单 击 确定 按钮 。 
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图 7-28 安装 后 的 控件 工具 包 图 7-29 添加 扩展 程序 


展 程序 向 导 


p 请 选择 扩展 程序 


请 选择 要 添加 到 TextBoxl HHE: 


с? t а = B 


AlwaysVi... Animatio... AutoComp ü PU ColorPic... DragPane... DropDown... DropShad. 


< 
说 明 : 


请 指定 扩展 程序 的 ID: 


TextBoxl_CalendarExtender 


图 7-30 “扩展 程序 向 导 ” 对 话 框 


添加 后 自动 生成 的 代码 如 下 : 


<asp:TextBox ID ="TextBox1" runat ="server" > </asp:TextBox > 
<asp:CalendarFxtender ID -"TextBox] CalendarFxtender" гопа -"server" 
Enabled ="True" TargetControlID ="ТехіВох1" > 
</asp:CalendarFxtender > 


第 5 2 ”设置 CanlendarExtender 的 属性 ,将 Format 设置 为 yyyy 年 MM 月 dd H, 
FirstDayOfWeek 设置 为 Monday。 
页 面 中 首先 声明 Ajax Control Toolkit 使 用 的 前 绥 : 
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«SGRegister assenbly -"AjaxControl Toolkit" namespace -"AjaxControl Toolkit" 
tagprefix ="asp" % > 


其 页 面 中 核心 代码 如 下 : 


<asp:ToolkitScriptManager ID -"Scripti'Bnagerl" runat -"server" > 
«/asp:ToolkitScriptManager > 
«asp:UpdatePanel ID -"UpdateFarell" runat -"server" > 
«Content Template > 
<asp:Iabel ID-"Label1" runat "server" Text 一 请 输 入 一 个 日 期 "></asp:Iabel > 
<br /> 
<asp:TextBox ID -"TextBox1" runat ="зегуег" > </asp:TextBox > 
Xasp:CalendarFxtender ID —"TextBox] CalendarExtender" rumat ="ѕегуег" 
Enabled "True" FirstDayOfWeek -"Morday" Format ="уууу 4F. MH ad H" 
TargetControlID -"TextBox] " > 
X/asp:Calendarkxtender > 
«/Content Template > 
«/asp:UpdateParel > 


第 6 步 在 浏览 嚣 中 查看 页 面 ,效果 如 图 7-31 所 示 。 
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今天 : June 24, 2014 


far R100% @ Internet 


图 7-31 使 用 CalendarExtender 控件 显示 日 历 


在 初始 页 面 加 载 完 成 后 , 单 击 TextBox 控件 ,获得 焦点 ,显示 当前 日 期 的 日 历 文本 框 ,在 
文本 框 上 任意 选择 年 月 .日 (示例 中 选择 为 2015 年 7 月 19 日 ) ,会 将 此 日 期 按照 设 定好 的 
“yyyy 年 MM H dd 日 "格式 显示 在 TextBox 控件 。 

再 次 单 击 TextBox 控件 ,会 在 日 历 文本 框 中 显示 TextBox 中 输入 的 信息 。 

FirstDayOfWeek 的 Monday 设置 体现 在 日 历 每 周 以 Mo( 周一 ) 开 始 。 

3. 使 用 PasswordStrength 控件 
第 1 步 打开 Visual Studio 2010 开发 环境 ,新 建 一 个 空 网 站 ,将 其 命名 为 cha7_6 ,添加 


一 个 Visual C# 的 Web 窗 体 ,命名 为 Default. aspx, 并 设置 为 起 始 页 。 
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第 2 步 构建 AJAX 环境 。 在 Default. aspx 页 中 添加 一 个 ScriptManager 控件 进行 页 面 
全 局 管理 。 

第 3 步 ” 添 加 一 个 Label 控件 ,将 其 Text 属性 设置 为 “使 用 文本 提示 密码 强度 ” ,用 于 提 
示 任 务 功 能 。 

第 4 步 ” 添 加 一 个 TextBox 控件 ,然后 将 Passw- 
ordStrength 控件 拖 忠 到 此 控件 上 , 即 完成 了 “添加 扩 
展 程序 ”效果 ,与 使 用 CanlendarExtender 控件 第 4 步 
作用 相同 。 添 加 后 效果 如 图 7-32 所 示 。 

添加 后 自动 生成 的 代码 如 下 : 


ToolkitSeriptMWanager - Scriptlanagerl 


使 用 文本 提示 密码 强度 
图 7-32 ”密码 强度 提示 控件 设置 


<asp:TextBox ID="TextBox1" runat ="server" ></asp:TextBox > 
<asp:PasswordStrength ID="TextBox] PasswordStrength" гопа ="server" 
TargetControlID ="TextBoxl" > 
</asp:PasswordStrength > 
第 5 步 ”设置 PasswordStrength 控件 的 属性 ,使 其 检测 TextBox 中 输入 的 密码 强度 并 
提示 。 
页 面 中 首先 声明 Ajax Control Toolkit 使 用 的 前 级 : 


<%@Register assembly ='AjaxControlToolkit" namespace -"AjaxControlToolkit" 
tagprefix ="asp" % > 
其 页 面 中 核心 代码 如 下 : 


<asp:ToolkitScriptManager ID ="ScriptManager1" runat ="server" > 
«/asp:ToolkitScriptManager > 
<asp:Iabel ID-"Tabell" nmt ="зегуег" Text 二 使 用 文本 提示 密码 强度 "></asp:Iabel > 
<asp:TextBox ID ="ТехіВох1" runat -"server" > </asp: TextBox > 
«asp:PasswordStrength ID-"TextBox] PasswordStrength" runat -"server" 
MinimniNuericCharacters ="1" MinimmSyrbolCharacters ="1" PrefixText 一 密码 强度 : "StrengthStyles =" 
textIndicator 1;textIndicator 2;textIndicator 3;textIndicator 4;textIndicator 5" 

TargetControl ID ="TextBox1 " TextStrengthDescriptiens MR% ;25 ;— Ri ДАНЕ" > 

«/asp: PasswordStrength > 


第 6 步 在 浏览 器 中 查看 页 面 , 效 果 如 图 7-33 所 示 。 
在 图 7-33 中 ,中 为 浏览 器 加 载 页 面 完 成 后 的 显示 效果 ,@) ~ @ 为 输入 不 同 强度 的 密码 


对 密码 强度 进行 提示 ,GO 为 当 密码 框 失 去 焦点 时 提示 信息 会 自动 消失 。 
【任务 小 结 】 


本 任务 对 CanlendarExtender 控件 , PasswordStrength 控件 \AutoCompleteExtenAJAX Control 
Toolkit 控件 工具 包 der 控件 进行 介绍 ,并 给 出 了 AJAX Control Toolkit 的 安装 方法 以 及 
CanlendarExtender 控件 „PasswordStrength 控件 的 简单 应 用 。 

【拓展 提高 】 

限制 输入 价格 。 

215 


后 显示 富 码 强度 - Vindors 1r (С сч „зл SIBI X [Bao c 
CET itg) #80 SEV KERW ТАШ EHW 


L] m - o æ- mv- 
密码 强度 : 很 好 


使 用 文本 提示 密码 强度 [aabb12@| (5) 密码 强度 : 好 
使 用 文本 提示 密码 强度 wc (2) 密码 强度 ， 一 般 
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图 7-33 ”使 用 PasswordStrength 控件 显示 密码 强度 


第 1 步 ”打开 Visual Studio2010 开发 环境 ,新 建 一 个 网 站 ,将 其 命名 为 cha7_7 ,默认 主 
WH Default. aspx, fE Default. aspx 页 面 添 加 一 个 
ScriptManager 控件 ,构建 AJAX 环境 。 je = 

第 2 步 ， 添 加 一 个 TextBox 控件 ,用 来 输入 价格 。 ToolkitScriptlanager - Scriptlanagerl 
然后 将 MaskedEditExtender 1 6 tü 8] iz FME ,效果 
如 图 7-34 所 示 。 图 7-34 ”限制 输入 界面 设计 

添加 后 自动 生成 的 代码 如 下 : 

<asp:TextBox DD="TextBoxl" runat ="server" > </asp:TextBox > 

«asp:MaskecEditExtender ID-"TextBol MaskededitExtender" runat ="server" 

TargetControl ID -"TextBoxl " > 

«/asp:MaskecEditExtender > 

MaskedEditExtender 控件 是 AJAX Control Toolkit 控件 工具 包 的 其 中 一 种 控件 ,可 以 用 来 
限制 文本 的 输入 。 通 过 设置 Mask 属性 ,可 以 只 人 允许 某 些 类 型 的 字符 /文字 被 输入 ,支持 的 
数据 格式 有 数字 .日 期 日 期 时 间 , 常 被 用 来 限制 用 户 输入 ,防止 错误 输入 ,如 在 本 应 该 输入 
数字 的 地 方 输入 非 数 字 的 内 容 。 

MaskedEditExtender 控件 常用 的 属性 及 说 明 如 表 7-7 所 示 。 

第 3 步 设置 MaskedEditExtender 的 属性 ,将 其 DisplayMoney 属性 设置 为 Left, Mask 设 
置 为 999 ,MaskType 设置 为 Number。 


表 7-7 MaskedEditExtender 控件 属性 及 说 明 


属 性 说 — BJ 


TargetControlID 所 要 实现 限制 功能 的 文本 框 ID ,如 TargetControlID = " TextBox1 " 
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ж Ж 说 明 


Mask 掩 码 , 如 Mask = "999" 


MaskType 掩 码 类 型 ,如 MaskType = " Number" 


AutoComplete 当前 时 间 


是 否 自 动 完成 ,如 选 true, 而 MaskType 为 数字 类 型 则 为 0, 日 期 时 间 类 型 则 为 


ClearMaskOnLostFocus 当 失去 焦点 时 是 否 清空 文本 


DisplayMoney 是 否 显示 本 地 货币 符号 


页 面 中 首先 声明 Ajax Control Toolkit 使 用 的 前 级 : 


<%@Register asserbl y ="AjaxControlToolkit" namespace ="AjaxControlToolkit" tagprefix ="asp" $ > 


其 页 面 中 核心 代码 如 下 : 


<asp:ToolkitScriptManager ID ="ScriptManager1" runat ="server" > 
</asp:ToolkitScriptManager > 
<asp:TextBox ID ="TextBox1" runat ="server" > </asp:TextBox > 
Xasp:MaskedEditExtender ID-"TextBoxl MaskecEditExtender" runat ="server" 
DisplayMney —"Left" Mask ="999" MaskType ="Nnber" TargetControlID = 
"TextBox1" > 
«/asp:MaskecEditExtender > 


第 4 步 在 浏览 器 中 查看 页 面 , 效 果 如 图 7-35 所 示 。 


/5 http://localhost:50 /2 http://localhost:50 /5 http://localhost:5070/chaT. T/D« 
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从 图 7-35 可 以 看 出 ， 


图 7-35 在线 考试 倒计时 实现 效果 


当 页 面 加 载 完成 时 , TextBox 显示 为 标准 控件 , 单 击 准备 输入 时 出 


Ji^ Y "是 DisplayMoney 属性 显示 了 本 地 的 货币 符号 。 在 输入 时 ,只 能 输入 数字 ,英文 汉字 
和 特殊 符号 在 录入 的 时 候 ,页 面 上 没有 反应 ,是 由 “MaskType = " Number" ”来 进行 的 限制 ,最 
大 数值 为 999 ,是 “Mask = "999" "限制 了 数字 的 最 大 值 。 


四 、 


项 目 小 结 


本 项 目 主 要 讲解 ASP . NET 的 AJAX 技术 ,主要 是 ASP . NET 提供 的 控件 ,其 次 在 项 目 
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中 可 以 考虑 使 用 AJAX 扩展 包 。AJAX 是 大 势 所 趋 ,读者 要 在 项 目 中 尽量 采用 ,不 能 满足 于 
传统 的 Web 效果 。 


五 、 项 目 考核 

1. 填空 题 

(1) AJAX 全 称 是 

(2) AJAX 框架 分 为 和 ° 

(3) 对 页 面 进行 全 局 管理 时 ,每 个 要 使 用 АТАХ 功能 的 页 面 都 需要 使 用 控件 ， 
且 只 能 被 使 用 一 次 。 

(4) 服务 器 控件 是 ASP. NET AJAX 中 最 常用 的 控件 ,允许 执行 页 面 的 局 部 刷 
新 ,页 面 中 所 使 用 的 AJAX 控件 必须 放 在 控件 中 才能 发 挥 其 作用 。 

(5) 利用 AJAX 的 控件 ,每 隔 一 段 时 间 固 定 触发 一 个 事件 ,让 刷新 有 了 时 间 
上 的 依据 。 

(6) Timer 控件 的 Interval 属性 是 以 为 单位 定义 的 ,其 默认 值 
为 

(7) Timer 控件 的 Enabled 属性 o 

(8) ASP .NET AJAX Control Toolkit 是 基于 之 上 构建 的 。 

(9) ASP .NET AJAX Control Toolkit 是 AJAX 控件 。 

(10) CanlendarExtender 控件 的 TargetControlID 属性 是 用 来 关联 А 

(11) PasswordStrength 控件 有 两 种 提示 方式 : ` o 

2. 简 答题 


(1) Web 应 用 的 AJAX 模型 是 什么 ? 

(2) AJAX 的 优点 是 什么 ? 

(3) Timer 控件 的 优 缺 点 是 什么 ? 

(4) Timer 控件 的 位 置 有 哪些 影响 ? 

(5) AJAX Control Toolkit 有 什么 作用 ? 

(6) 简 述 使 用 AutoCompleteExtender 控件 的 方法 。 

3. 上 机 操作 题 

(1) 创建 一 个 网 站 ,在 Default. aspx 页 面 添加 一 个 TextBox 控件 和 一 个 Label 控件 ,在 
TextBox 控件 中 输入 文本 内 容 , 输 入 完成 后 无 整体 页 面 刷 新 并 在 Label 控件 中 显示 TextBox 
控件 中 输入 的 内 容 。 

(2) 创建 一 个 网 站 ,在 Default. aspx 页 面 添加 一 个 Label 控件 用 于 随机 显示 名 言 警 句 ， 
用 Timer 控件 控制 更 换 名 言 警句 时 间 为 2 分 钟 。 

(3) 创建 一 个 网 站 ,采用 进度 条 方式 使 用 PasswordStrength 控件 显示 密码 强度 。 
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ЖЮЗ Web 服务 
= 引言 


目前 ,各 大 主流 技术 供应 商 无 一 不 在 关注 Web 服务 的 发 展 , 从 Microsoft 的 . NET 到 IBM 
公司 Web Service ,都 体现 了 这 些 重量 级 的 技术 提供 者 对 Web 服务 的 重视 。 

Web 服务 利用 http 和 soap 协议 使 用 数据 在 Web 上 传输 ,通过 调用 Web Service 可 以 执 
行 从 简单 的 请 求 到 复杂 的 业务 处 理 的 任何 功能 。 


二 、 项 目 要 点 


本 项 目 通 过 一 个 项 目 提供 数学 计算 的 服务 ,一 个 项 目 使 用 服务 的 实例 ,讲解 了 Web Wit 
务 的 概念 .Web 服务 的 创建 以 及 使 用 。 要 求 了 解 Web 服务 的 概念 ;掌握 Web Service 的 创建 
和 引用 。Web 服务 是 最 近 应 用 程序 开发 的 一 个 热门 ,实现 方式 有 很 多 ,ASP . NET 提供 的 方 
式 最 为 简单 。 


=, 9 
使 用 Web 服务 实现 简单 数学 计算 。 
【任务 描述 】 


项 目 经 理 要 求 小 王 开发 的 项 目 给 其 他 项 目 提供 简单 数学 计算 的 接口 , 即 其 他 项 目 可 以 
访问 小 王 项 目 里 的 数学 计算 功能 。 这 个 需求 和 以 往 的 需求 差别 很 大 ,以 前 的 需求 都 是 在 同 
一 个 项 目 中 ,而 这 个 需求 是 自己 的 项 目 为 其 他 项 目 提供 服务 ,在 ASP . NET 中 ,Web 服务 正 
好 可 以 解决 这 个 问题 。 

【任务 目的 】 

(1) 掌握 创建 Web Service 的 过 程 。 

(2) 掌握 引用 Web Service 的 过 程 。 


[257%] 

本 任务 和 本 书 中 以 前 的 所 有 任务 都 有 明显 不 同 , 本 任务 不 是 一 个 项 目 ,而 是 两 个 项 目 ， 
一 个 项 目 提供 计算 功能 , 即 服务 , 另 一 个 项 目 使 用 这 些 功 能 , 即 消费 , 当然 也 可 以 根据 需要 变 
成 两 个 都 提供 服务 ,同时 也 都 消费 。 

【基础 知识 】 

1. Web 服务 概念 

Web 服务 是 自 包 含 .模块 化 的 应 用 程序 ,可 以 在 网 络 中 被 描述 发 布 .查找 以 及 调用 。 
它 是 技术 规范 ,这 些 规 范 使 得 项 目 间 .系统 间 可 以 通过 网 络 相互 操作 ,为 企业 解决 数据 孤岛 
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提供 了 有 效 手 段 。 

2. Web 服务 特征 

(1) 完好 的 封装 性 。Web 服务 部 署 好 后 ,使 用 者 仅 能 访问 到 该 对 象 提供 的 功能 列表 ， 
对 于 功能 的 实现 细节 无 法 访问 。 

(2) 松 耦 合 性 。 项 目 之 间 只 有 方法 调用 与 被 调用 的 关系 ,对 于 功能 实现 的 技术 细节 ， 
Web 服务 没有 任何 要 求 。 

(3) 使 用 协议 的 规范 性 。Web 服务 使 用 标准 的 描述 语言 来 描述 ,并 且 描 述 的 服务 界面 
是 可 以 发 现 的 。 

(4) 高 度 的 集成 能 力 。Web 服务 采用 简单 . 易 理 解 的 标准 ,完全 屏蔽 了 平台 的 差异 , 实 
现 了 当前 环境 下 最 高 程度 的 可 集成 性 。 

知识 链接 : Web 服务 是 一 种 服务 导向 架构 的 技术 ,通过 标准 的 Web 协议 提供 服务 , 目 
的 是 保证 不 同 平台 的 应 用 服务 可 以 互 操作 。 根 据 МЗС 的 定义 ,Web 服务 ( Web service) 应 
当 是 一 个 软件 系统 ,用 于 支持 网 络 间 不 同 计算 机 的 互动 操作 。 网 络 服务 通常 是 许多 应 用 程 
序 接口 (API) 所 组 成 的 ,它们 通过 网 络 ,例如 国际 互联 网 ( Internet ) 的 远程 服务 器 端 ,执行 客 
户 所 提交 服务 的 请 求 。W3C 的 定义 涵盖 诸多 相 异 且 无 法 分 类 的 系统 ,通常 是 指 有 关 主 从 式 
架构 之 间 根 据 SOAP 协议 进行 传递 XML 格式 消息 。 无 论 定义 还 是 实现 ,Web 服务 过 程 中 会 
由 服务 器 提供 一 个 机 器 可 读 的 描述 (通常 基于 WSDL) 以 辨识 服务 器 所 提供 的 Web 服务 。 
另外 ,虽然 WSDL 不 是 SOAP 服务 端点 的 必要 条 件 , 但 目前 基于 Java 的 主流 Web 服务 开发 
框架 往往 需要 WSDL 实现 客户 端的 源 代 码 生 成 。 一 些 工业 标准 化 组 织 , 比 如 WS-I, 就 在 
Web 服务 定义 中 强制 包含 SOAP 和 WSDL, 

3. Web 服务 创建 

Web 服务 也 是 一 个 C# 类 ,不 过 它 是 一 个 以 . asmx 为 后 级 和 一 个 以 . es 为 后 级 的 两 个 文 
件 ,而 不 仅仅 是 一 个 .cs 后 级 的 文件 ,但 是 创建 Web 服务 类 和 普通 类 的 创建 区 别 很 小 。 创 建 
Web 服务 后 ,在 其 . es 文件 中 编写 功能 代码 ,注意 要 想 成 为 Web 服务 的 方法 ,被 自身 之 外 的 
应 用 调动 ,在 方法 的 前 面 一 定 要 加 上 WebMethod 属性 。 

4. Web 服务 调用 

在 一 个 项 目 中 , 想 要 调用 Web 服务 ,首先 要 引用 Web 服务 ,引用 Web 服务 需要 知道 
Web 服务 所 在 位 置 。Web 服务 所 在 位 置 可 分 为 3 Ж. 

(1) 此 解决 方案 中 的 Web 服务 ; 

(2) 本 地 计算 机 上 的 Web 服务 ; 

(3) 本 地 网 络 上 的 UDDI 服务 器 。Web 服务 的 引用 都 是 可 视 化 操作 ,比较 简单 。 

在 使 用 Web 服务 的 功能 之 前 ,需要 实例 化 对 象 ,例如 : 

localhost .WebServiosl service new localhost.WEbServicel () ; 
代码 中 localhost 是 Web 服务 的 引用 名 ,在 引用 时 可 以 修改 ,本 过 程 中 采用 系统 默认 ， 
WebServicel 是 提供 Web 服务 的 类 的 名 称 。 之 后 就 可 以 像 调用 本 地 类 的 方法 一 样 调用 Web 
服务 。 

小 提示 : Web 服务 同时 在 两 个 或 多 个 项 目 之 间 调 用 时 使 用 。 

【任务 实施 】 

第 1 步 ”创建 空 网 站 chap8-1 ,网 站 创建 成 功 后 ,解决 方案 资源 管理 器 窗口 中 ,可 以 看 到 
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在 网 站 的 上 边 有 “解决 方案 8-1” 字 样 ,选中 “解决 方案 8-1”, 右 击 , 从 弹出 的 快捷 菜单 中 选中 


“添加 ”1“ 新 建 项 目 ” 命 令 , 如 图 8-1 所 示 。 
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图 8-1 在 解决 方案 中 添加 新 项 目 


小 提示 : 必须 在 解决 方案 下 添加 项 目 ,否则 两 个 项 目 不 


项 目 ( 
| ЕЕ 10) — C ER 


тех 


能 同时 打开 ,也 就 无 法 测试 


第 2 步 ”在 “资源 管理 器 "中 添加 “新 建 项 目 " ,打开 * 新 建 项 目 " 窗 口 , 选 中 ASP 
. NET Zi Web 应 用 程序 , 填 入 名 称 WebService8-1 ,设置 位 置 为 d: Vnetword V chap8-2, 如 


图 82 所 示 。 
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WebServie8-2 


用 于 创建 内 有 Web 用 户 界面 的 应 用 程序 
的 空 项 目 


dinetwork\chap8-1| 


图 8-2 添加 ASP .NET 空 Web 应 用 程序 
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第 3 步 ， 在 新 建 项 目 WebService8-2 中 ,添加 “Web JR” ,操作 和 添加 Web 窗 体 接近 ， 
不 同 之 处 在 于 ; 在 “添加 新 项 ”时 ,选中 Web 服务 ,而 不 是 Web 窗 体 ,如 图 8-3 所 示 。 


已 安装 的 模板 

4 Visual C# 
Web 
Windows Forms 
WPF 

яя 

RB 

数据 

Reporting 
Silverlight 
Worldlow 


TERME: | 默认 值 Z 
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图 


搜索 已 安装 的 模板 » 


ASP.NET 模块 


Dynamic Data #2 


WCF 服务 


WCF 数据 服务 


Web 服务 


Web 配置 文件 


Visual C 


Visual C 


Visual C 


Visual Сё 


Visual Сё 


Visual C 


Visual Сё 


^| Bk Visual C# 


图 8-3 添加 Web 服务 


用 于 创建 Web 服务 的 可 视 设计 类 


第 4 步 ” Web 服务 创建 成 功 , Visual Stuido 2010 会 自动 打开 新 创建 的 Web 服务 编写 代 
码 的 文件 ,并 且 已 经 自动 生成 了 “ Hello World" 方 法 ,这 个 方法 可 以 被 其 他 项 目 中 的 类 调用 ， 
如 图 8-4 所 示 。 


сө chap8-1 (2) - Microsoft Visual ио) 


эз 
BasicPrefilel 1] 


ve шя. авантпа- 


图 84 Web 服务 创建 文件 


第 5 步 ” 在 类 的 里 面 ,方法 Hello World 下 边 ,编写 代码 如 下 所 示 ,也 可 以 使 用 下 边 代码 
替换 掉 Hello World 方法 : 


[КЕСМЕК] 
public double sum (double a, double b) 
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return a +b; 


[смео] 


public double subtract (double a, double b) 


retum a +; 


[WscMethod] 


public double miltiply (double a, double b) 


retuma * b; 


[WscMethod] 


public double divide (double a, double b) 


retum a / b; 


第 6 步 ТАЧ, erp WebServicel "文件 , 右 击 ,从 弹出 的 快捷 菜单 中 选择 “在 浏览 
器 中 查看 "命令 , 则 在 浏览 器 中 打开 名 为 WebServicel 的 服务 ,服务 中 的 方法 会 在 网 页 中 风 
列 出 来 ,并 且 可 以 单 击 调用 ,如 图 8-5 所 示 。 


[loe х (ав x YC во х C loe: x V favs x [sz x 9 Cs x Y [loo x ( [) We x (Сое x V D loe x П ху m we x V 
£ > C |D localhost3700/WebService1.asmx з= 


WebServicei Г 


RATIH AXELEN. ERKKA. 
~ HelloWorld 
* divide 
* multiply 
* subtract 


* sum 


此 Web 服务 使 用 http:/ /tempuri.org/ 作为 默认 命名 空间 " 
|| 建议 : 公开 XML Web services 之 前 ,请 更 改 对 认 命名 空间 。 


每 个 XML Web services gw —144—(6 E78. UL NE PERIERE Web 上 的 其 他 服务 区 分 开 。http://rempuri.org/ 可 用 于 处 于 开发 阶段 的 XML Web services, 而 已 发 的 
XML Web services 应 使 用 更 为 永久 的 命名 空间 ” 


| Sungesnescmeg эм. web services: Від, BIELAN temet 二 名作 为人 如 空 19 名 分 。 RENES XML Web services васии: URL, Велма Web 上 的 
= (XML Web services 命名 空间 为 U 


|| же ASP.NET Bi XML web services Bl, mens WebService 特性 的 Namespace ШЕРА @ а. WebService 特性 通用 于 世 含 XML Web services BENA. TENBA 
命名 空间 设置 为 "http://microsoft.com/webservice: 


| cs 


[WebService (Nanespacee"http:/ /нїсговоё.сов/меЬзегу1сез/") 1 
Public class MyWebService { 
HER 


Visual Basic 
AebService (liane space:u"hztp://microsofr.com/webservices/*]» Public Class MyWebfervice 
EX 
End Class 


Ce 


图 8-5 在 网 页 中 打开 Web 服务 
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第 7 步 TE chap8-1 中 引用 Web 服务 ,在 资源 管理 器 中 右 击 сһар8-1 项 目 ,从 弹出 的 快 
捷 菜 单 中 选择 “添加 Web 引用 ”命令 ,如 图 8-6 所 示 。 弹 出 “添加 Web 引用 ”对 话 框 ,如 图 8-7 
所 示 。 


Д еле WebSenice1 


DVebllet hod] 
public double sun(double a, double b) 


CuiltShih+A 
Shift+Ah+A 
ls subt ract (double a, double b) 


- 


is multiply(double a, double b) 


publie double divide(dotble s, double b) 
t 


图 8-6 添加 Web 引用 


请 定位 到 提供 Web 服务 的 URL, 然后 单 击 “ 添 jn 引用 ”， 添 加 位 于 该 URL 上 的 所 有 可 用 服务 . 
leelaaea 


URLU: | ja 


m. < | 位于 此 URL 上 的 Web B: 
Hh web та 


quM Web 服务 的 起 始点 。 您 可 以 单 击 下 面 的 檬 接 ， 或 者 在 地 址 栏 中 
M Лала URL。 
浏览 至 : 

。 此 解决 方案 中 的 _Web 服务 

= 本 地 计算 机 上 的 _Web 服务 


. 
在 您 的 本 地 网 络 上 查 词 UDDI RE Web 引用 名 (N): 


图 8-7 “添加 Web 引用 ”对 话 框 


第 8 步 单 击 “ 添 加 Web 引用 "对话 框 上 的 “此 解决 方案 中 的 Web 服务 " 超 链接 ,会 自 
动 搜索 当前 解决 方法 中 的 所 有 Web 服务 ,并 罗列 出 来 ,如 图 8-8 所 示 。 
第 9 步 单 击 此 解决 方案 中 的 Web 服务 下 的 WebServicel ,打开 WebServicel 所 提供 的 
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请 定位 到 提供 Web 服务 的 URL ,然后 单 主 “ 添 加 引用 ” ， 添 加 位 于 该 URL 上 的 所 有 可 用 服务 . 


|оо|ааа 

шш. 7 -a 

此 解决 方案 中 的 _Web 服务 2] 位 于 此 URL 上 的 Web 服务 (S): 
J| | 下 夯 列 出 了 此 解决 方案 中 可 用 的 Web 服务 。 单 击 服务 链接 可 以 浏览 该 服务 * ig 
| EH 项 目 URL 

WebServicel Ҹеһбегуіе VehServicel.asmr 


Web 引用 名 (N): 
SORS IRR CR. 
| - 


图 8-8 列 出 所 有 Web 服务 


功能 方法 ,如 图 8-9 所 示 。 


请 定位 到 提供 Web 服务 的 URL. 然后 单 击 “ 添 j03| 用 ”， 添加 位 于 该 URL 上 的 所 有 可 用 服务 , 
|оо|ааа 


URL(U): — httpy/localhost3700/WebServicelasmx ~ 日 


š | 位 于 此 URL 上 的 Web 服务 (S): 
| WebServicel РТТ 5 


жетлеп. RERE. SEES. = WebServicel 


* HelloWorld 


* divi 

* multiply 

* subtract 

V Web 引用 名 (N): 
localhost 


||| 此 Web 服务 使 用 http://tempuri.org/ FARUS & ile 添加 引用 (R) 
建议 : 公开 XML Web services 之 前 ， 请 更 改 蒜 认命 名 空间 。 


每 个 XML Web services &EI.—498 HALEN. UU Eos EH REATE 
Web 上 的 其 他 服务 区 分 开 。http://temmpuri.org/ 可 局 于 处 于 开发 外 各 的 XML Web 
services. MERAH XML Web services Етел EMN. 


应 使 用 您 控制 的 命名 空间 来 标 识 XML Web services。 例 各， 可 以 使 用 公司 的 Internet £ 
老 作 为 会 攻 空间 的 一 部 分 。 尽管 有 许多 XML Web services #£ iQ URL. GENTO 
指向 Web Еб. (XML Web services $220% URI. ) 


«E m р 


使 用 ASP.NET 创造 XML Web services 时 ， 可 以 使 用 WebService 特性 的 - J 


——— = 


图 8-9 WebServicel 提供 的 功能 方法 


第 10 步 ”直接 单 击 “ 添 加 Web 服务 "对 话 框 的 “添加 引用 ”按钮 ,就 完成 了 Web 服务 的 
引用 。 
第 11 步 ”在 chap8-1 网 站 中 ,添加 Web Ж Default. aspx ,并 向 设计 视图 窗口 中 放 和 两 
个 TextBox 控件 、 一 个 DropDownList 控件 、 一 个 Button 控件 和 一 个 Label 控件 , 如 
图 8-10 所 示 。 
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I E [Button Label 


图 8-10 放 入 控件 


第 12 步 ” 修 改 控件 属性 ,为 DropDownList 添加 ”+、- * 、/”4 项 ,如 图 8-11 所 示 ; 修 
W Button 的 Text 属性 为 : = ,Lable 的 Text 属性 为 空 字符 串 ,属性 设置 好 后 的 设计 界面 效果 
如 图 8-12 所 示 。 


图 8-11 修改 控件 属性 


Fw) 了 
| 


图 8-12 设置 好 属性 的 设计 界面 


第 13 25 ХЕ Default. aspx 中 ,双击 Buttonl 按钮 ,进入 Buttonl _Click 方法 ,为 时 间 
Button1_Click 编写 处 理 代 码 ,代码 如 下 : 


protected void Buttonl Click (doject sender, EventArgs e) 
{ 

string a =this.TextBox1 .Text; 

string b -this.TextBad Text; 

double aa -Convert.. TcDouble (а); 

double kb -Convert.. ToDouble (р); 


localhost.WebServioel service new localhost.WebServicel () ; 
if (this.DropDownListl.SelectedValue ==" +") 
{ 
this.Label1.Text=(service.sm(aa, Њ)) .ToString () ; 
} 
else if (this.DraoDownlistl.Selectedvalue =="-") 
{ 
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this.LIabel1.Text=(service-subtract (aa, bb)) .TcString () ; 
) 
else if (this.DraoDownListl.Selectedvalue ==" = ") 
{ 
this.Iabell .Text = (service.miltiply(aa, Hb)) .Tostring(); 
} 
else if (this.DrapDownListl.Selectedvalue =="/") 
{ 
this.Iabell.Text -(service.divide (aa, bb)) .ToString () ; 
) 
) 


第 14 步 ”启动 调试 ,在 网 页 中 输入 5 和 6, 青 在 下 拉 框 选中 * * ”, 单 击 ”= "按钮 后 显示 
出 5 乘 6 的 积 ,如 图 8-13 所 示 。 


e> C [n localhost:5996/chap8-1/Default.aspx 


b * +] Б E 30 


图 8-13 ”运动 效果 


【任务 小 结 】 

本 任务 实现 了 一 个 简单 的 数学 计算 ,本 来 是 不 需要 使 用 Web 服务 技术 的 ,但 是 如 果 方 
法 的 创建 和 调用 不 在 同一 个 应 用 程序 中 ,此 时 Web 服务 是 一 个 好 的 选择 。 

本 章 的 重点 是 Web 服务 的 创建 ,引用 和 调用 ,在 一 个 项 目 中 创建 Web 服务 ,在 另 一 个 
项 目 中 引用 和 调用 Web 服务 ,关于 数学 计算 和 页 面部 分 的 设计 不 是 本 项 目的 重点 ,在 此 主 
要 掌握 和 Web 服务 有 关 的 概念 以 及 操作 过 程 即 可 。 

【拓展 提高 】 

1. 面向 服务 的 软件 架构 

面向 服务 架构 可 以 根据 需要 通过 网 络 对 松散 耦合 的 粗 粒度 应 用 组 件 进 行 分 布 式 部 署 、 
组 合 和 使 用 。 

随 着 软件 需求 的 扩大 ,软件 系统 变 得 越 来 越 复杂 ,这 时 需要 一 种 更 加 合理 的 方式 将 不 同 
类 型 ,不同 位置 的 系统 结合 起 来 ,这 就 需要 Web 服务 技术 。 

2. Web 服务 核心 技术 

Web 服务 的 核心 技术 主要 包括 SOAP ( 简单 对 象 访问 协议 ) 、WSDL( Web 服务 描述 语 
言 ) 和 UDDI( 通 用 描述 发 现 和 集成 ) ,它们 都 是 以 XML 文档 的 实行 表述 的 。 

Web 服务 体系 结构 基于 3 种 角色 之 间 的 交互 ,这 3 种 角色 为 服务 提供 者 .服务 注册 中 心 
和 服务 请 求 者 。 

3. 客户 端 

ASP . NET 应 用 程序 服务 的 客户 端 可 以 为 不 同类 型 ,并 且 可 以 在 不 同 的 操作 系统 上 运 
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行 。 这 些 客户 端 主要 如 下 。 
(1) AJAX 客户 端 。 
(2) .NET Framework 客户 端 。 
(3) SOAP 客户 端 。 


四 、 项 目 小 结 


本 项 目 设计 的 知识 理论 部 分 难度 较 大 ,但 是 在 . NET 中 ,微软 公司 对 Web 服务 进行 了 高 
水 平 的 封装 ,封装 使 得 在 开发 过 程 中 基本 不 需要 掌握 Web 服务 的 理论 知识 ,只 需要 知道 在 
Visual Studio 开发 工具 中 如 何 创 建 . 引 用 和 调用 Web 服务 即 可 。 


五 、 项 目 考核 


1. 简 答题 

(1) 简 述 Web 服务 的 创建 和 引用 。 

(2) 简 述 上 网 检索 项 目 间 调用 的 技术 。 

2. 上 机 操作 题 

(1) 使 用 Web 服务 ,实现 学 生 信 息 的 呈现 。 

(2) 使 用 АТАХ 调用 Web 服务 ,实现 学 生 信 息 的 添加 .修改 和 删除 。 
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项 目 9 成 绩 管理 系统 
一 、 引 言 


本 项 目 是 一 个 综合 性 项 目 ,项 目 不 大 但 技术 要 求全 面 ,涉及 ASP. NET 最 基础 .最 核心 的 
知识 和 技术 。 学 生 通 过 这 个 项 目 ,可 以 了 解 到 应 用 程序 开发 的 全 过 程 。 


二 、 项 目 要 点 


通过 开发 一 个 小 项 目 掌握 应 用 程序 开发 的 全 面 知 识 和 技术 ,促使 学 生 对 应 用 系统 开发 
的 理解 更 加 全 面 和 系统 ,培养 学 生 使 用 ASP. NET 编程 技术 解决 实际 问题 的 能 力 。 


三 、 任 务 
任务 9-1 系统 分 析 

系统 用 户主 要 有 3 类 : 学 生 教师 和 系统 管理 员 。 学 生 的 需求 是 查看 自己 的 课程 成 绩 
和 查看 课程 信息 ;教师 的 需求 是 管理 学 生 的 课程 成 绩 、 查 看 学 生 信息 和 查看 课程 信息 ;管理 
员 的 需求 是 对 学 生 信 息 进行 管理 对 课程 信息 进行 管理 和 对 系统 用 户 进行 管理 。 
任务 9-2 系统 设计 

1. 功能 设计 

学 生 功 能 : 查看 成 绩 .查看 课程 。 

教师 功能 : 成 绩 管 理 .查看 学 生 ,查看 课程 。 

管理 员 功 能 : 学 生 管理 .课程 管理 ,用户 管理 。 

2. 数据 库 设计 

系统 需要 4 张 数据 库 表 ,如 表 9-1 ~ R 9-4 所 示 。 


表 9-1 Student X 


列 名 数据 类 型 语 义 备 注 
sno varchar( 20 ) 学 号 主键 
sname varchar(50) 姓名 
ssex varchar(2) 性 别 
sage int 年 龄 
sdept varchar(100) 系 别 
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表 9-2 Course X 


列 名 数据 类 型 语 义 备 注 
cno varchar(20) 课 号 主键 
cname varchar( 50) 课程 名 
срео varchar(2) 前 导 课 
ccredit int 学 分 

表 9-3 SCR 
列 名 数据 类 型 语 义 备 È 
sno varchar(20 ) 学 号 主键 
cno varchar(20) 课 号 主键 
score Int 成 绩 

R94 User Ж 
列 名 数据 类 型 语 义 备 È 
id int 编号 主键 Identity 
username varchar(50) 用 户 名 
password. varchar( 50) 密码 
role int 角色 


任务 9-3 系统 实现 


1. 登录 功能 实现 
登录 界面 如 图 9-1 所 示 。 


| € > e (D localhost2206/chap9/Login aspx 


图 9-1 登录 界面 
:230- 


登录 Login. aspx 代码 如 下 : 


«table align "center" class ="stylel" style -"padding -top:150px;" > 
«tr» 
«аР: «td» 
<td> 
«asp:TextBox ID="tbxUserCode" runat ="server" > </asp:TextBox > 
</td> 
«tr» 
«tr» 
«td»: «td» 
«td > <азр:ТехіВох ID ="thkPassword" runat ="server" TextMode "Password" > 
</аѕр:ТехіВох > 
</td> 
</tr> 
<tr> 
«аё: </td> 
«td > «asp:RadicButtonList ID -"rblRole" runat ="server" > 
<asp:ListItem Selected "True" Value ="1" >° «/asp:listItem» 
<asp:ListItem Value ="2" > ИЙ «/asp:ListItem» 
<asp:ListItem Value ="3" > 管理 员 «/asp:ListItem» 
</asp:RadicButtonList > 
</td> 
</tr> 
<tr> 
«td »&nbsp; </td> 
«td > «asp:Button ID ="Buttonl" runat —"server" Text "登录 " onclick- 
"Button Click" / ></td> 
</tr> 
«г> 
«td »&nbsp; </td> 
«td > «asp:label ID-"IblMessage" runat ="server" > «/asp:Tabel ></td> 
</tr> 
</table> 


登录 Login. aspx. cs 代码 如 下 : 


using System.Data.SqlClient; 
public partial class Login : System.Web.UI.Page 
{ 
protected void Buttonl Click(dbject sender, EventArgs e) 
t 
string userCode -this.tbxUserCode Text; 
string password -this.tbxPassword. Text; 
string role -this.rblFole.Selectedvalue; 
string sql -"select * frm [user] where userCode ='" 4userOode +"" and 


role -"" +ҥойе+"'"; 
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["connstr"]; 

SqlConnecticn conn =rew SqlConnecticn (url) ; 
сопп.Ореп  ; 
Sc Camend ard -new Sqlcamand (sql, com) ; 
SqlDataReader sdr -amd.ExecuteFeacer () ; 
if (sdr.Read) 
{ 

if (password ——sdr["password"] .ToString()) 


Session |["userCode"] =sdr ["userCode"] .TcString () ; 
Session ["role"] «ole; 
Response.Fedirect ("Default.aspx") ; 


else 


this. IblMessoge. Text "用 户 名 或 密码 错误 "; 


this.lblMessage.Text =" 用 户 名 或 密码 错误 "; 


学 生 登 录 成 功 后 界面 如 图 9-2 所 示 。 
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J D lecalhost2206/chapS/C x X 


€ > QC |D localhost:2206/chap9/Default.aspx 


F it Google Chrome 浏览 器 保存 您 的 到 码 吗 了 | 保存 至 码 | ILS ЛЕНӘ | 


| EE 


[р 


查看 课程 


. Ee 


图 92 学生 登 录 成 功 后 界面 


学 生 登 录 成 功 后 Default. aspx 代码 如 下 : 


«table width ="1000рх" align "center" > 
«tr style -"height:50px; background -color:8333d3;" > < colspan 22" style = 
"padding -left :300px; color: 撕 Effff;font —size:28px;" > 成 绩 管理 系统 </td></tr> 
«tr style "width: 100%; background -oolor:£eecee;" > 
«td style="width: 120px; vertical -align:tcp;" > 
<asp:TresView Ш ="TreeVienl" гла "server" ?«/asp:TreeView > «/td > 
«td» <iframe id-"T1" папе ="main" src ~"about :blank" width ="100%" 
height ="600рх" > «/iframe > </td> 
</tr> 
</table> 


学 生 登 录 成 功 后 Default. aspx. cs 代码 如 下 : 


protected void Page Ioad(doject sender, EventArgs e) 
{ 
if(!this.IsPostBack) { 
this.TreeViewl .Target -"main"; 


Object o -Sessian ["role"] ; 
if(o--null) 
{ 
Response.Write (" «div style -'width:200px; margin:0 auto;font -size: 
28px;' > 
请 先 登 录 <br >"); 
Response.Write ("uN 1? 击 ; А : ёо «a href ='Iogin.aspx' target =' blank' > 
登录 页 </a ></div >"); 
retum; 
) 
string role =Sessicn["role"] .ToString() ; 
if (role =="1") 
{ 
Teabe nodel -new TresNbde ("EF MRA"); 
nadel .NavigateUrl -"ScoreView.aspk''; 
TrecNode node? new TresNpde ("查看 课程 "); 
node2 .NavigateUrl ="CourseView.aspx"; 
this.TreeViewl .Nodes .Add (nodel ) ; 
this.TreeViewl .Nodes .Dod (node2) ; 
) 
else if (role =="2") 
t 
Teabe nokl -new Treehode ("成 绩 管理 ") ; 
nol .NavigateUrl -"ScoreManage .aspx"; 
TresNpde node2 new TresNpde ("查看 学 生 "); 
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TresNpde node3 -new TreeNode ("ARRE"); 
node3 .NavigateUrl -"CourseView.aspx"'; 
this.TresViewl .Nodes Ak (nol); 
this.TreeViewl .Nodes Ac (no?) ; 
this.TreeViewl .Nodes .Ack (node3) ; 
} 
els if (role =="3") 
{ 
TresNpde nodel new TreeNode ("FER"); 
rcdel .NavigateUrl ="StudentManage .aspx" ; 
TreeNode node -new TreeNode ("课程 管理 "); 
node2 .NavigateUrl ="CourseMenage asp 
TrecNode node3 -new Treo ("用 户 管理 "); 
node3 .NavigateUrl ="UserManage .aspx"; 
this.TreeViewl .Nodes ck (пофе1); 
this.TreeViewl .Nodes .Add (node2) ; 
this.TreeViewl .Nodes .Add (node3) ; 


) 


2. 学 生 功 能 
查看 成 绩 界 面 如 图 9-3 所 示 。 


< Ix) 
J D localhost2206/chap9/0 x XL Ë 
€ > Q [D localhost:2206/chap9/Default.aspx E m = 


Ф Mit Google Chrome 浏览 器 保存 您 的 区 码 吗 7 此 网 站 一 香 不 保存 至 码 


201403050001 1 数据 库 系统 原理 92 
201403050001 = 2 高 等 数学 78 
201403050001 = 4 操作 系统 原理 т2 
201403050001 E m сай 88 


图 9-3 查看 成 绩 界 面 


查看 成 绩 ScoreView. aspx 代码 如 下 : 


<asp:GridView ID -"GridViewl" runat ="server" AutcGenerateColumns ="Еа15е" 
CellPadding ="4" ForeColor ="B33333" GridLines ="None" Width ="500px" > 
«AltematingRowStyle BackColor -"White" /> 
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«Colums > 
<asp:BoundField DataField "sno" Header Text 一 学 号 " /> 
<asp:BondField DataField ="sname" HeaderText 一 姓名 " /> 
«asp:BoundField DataField ="спо" HeaderText =" 5" /> 
<asp:BoundField DataField ="спапе" HeaderText 一 课程 名 " /> 
<asp:BoundField DataField -"score" HeaderText =" 成 绩 " /> 
«/Colums > 
«FooterStyle BackColor ="990000" Font -Bold -"True" ForeColor —ihite" /> 
«HeacerStyle BackColor ="990000" Font -Bold -"True" ForeColor —"ihite" /> 
«PagerStyle BackColor ="FF0066" ForeColor =" 833333" HorizentalAlign = 
"Center" /> 
<RowStyle BackColor ="#ЕЕВГ6" ForeColor 833333" / > 
«SelectecFosStyle BackColor —'&EOO66" Font -Pold —"True" ForeColor Navy" / > 
«SortedhscendingoellStyle BackColor ="#ТЕ5АС" / > 
«SortedhsoendingHeaderStyle BackColor ="#00000" / > 
<SortedDescendingCellStyle BackColor ="ФСЕБО)" / > 
<SortedDescendingHeaderStyle BackColor =" 820000" / > 


</asp:GridView > 
查看 成 绩 ScoreView. aspx. cs 代码 如 下 : 
using System.Data; 


using System. Data .SqlClient; 
public partial class scoreView : System.Web.UI.Page 


protected void Page Ioed(doject sender, EventArgs e) 
{ 
if(!this.IsPostBack) ( 

if (Session["userCode"] --null) 

1 
Response.Write ("你 没有 权限 访问 该 页 面 "); 

} 

else 

{ 
string sql -"select a.sm sno,a.sname sname,b.cno аю, 

b.cname апапе,с.ѕооге score 
fram student. a, course b, sc c where a.sno -c.sno and b.ano = 
c.ano and 
a.sno ='" 4Session ["userOode"] .ToString () +"'"; 
HPSettings ["oonnstr"] ; 

SglOonnection conn =new SqlOonnecticn (url) ; 
SqlCamand ard =new SqlCamand (sql, oonn) ; 
SdlDataAdapter sda -new SglDataAdapter (ard); 
DataSet ds -new DataSet. (); 
sda.Fill (ds); 


Sce 


this.Gridviewl .DataSource =ds.Tables [0]; 
this.GridViewl .DataBind () ; 


) 
查看 课程 界面 如 图 9-4 所 示 。 


J D localhost2206/chapo/D x V. 


€ > C [D localhost2206/chap9/Defaullaspx ET = 


早 mit Google Chrome 浏览 可 保存 您 的 至 码 吗 |) ipia mre EG * 


1 数据 库 系统 原理 5 5 
2 高 等 数学 4 
3 管理 信息 系统 1 3 
4 操作 系统 原理 6 4 
5 数据 结构 与 算法 n 6 
6 系统 方法 论 1 
7 (语言 6 4 


图 94 查看 课程 界面 
查看 课程 CourseView. aspx 代码 如 下 : 


<asp:GridView ID-"GridViewl" ропа -"server" AutcGenerateColums -"False" 
GellPadding ="4" ForeColor ="833333" GridLines ="None" Width ="500рх" > 
«AltematingRowStyle BackColor —"White" / > 
«Colums > 
«asp:BoundField DataField ="спо" Header Text: =" ЕК" /> 
«asp:BoundField DataField ="спапе" HeaderText = 课程 名 " /> 
«asp:BoundField DataField "qono" HeaderText = 前 导 课 课 号 2" /> 
«asp:BoundField DataField -"ocredit" HeaderText 二 学分" /> 
</Colums > 
XFooterStyle BackColor ="990000" Font -Bold "True" ForeColor ="White" /> 
XHeaderStyle BackColor ="990000" Font -Bold "True" ForeColor -"White" /> 
«PagerStyle BackColor —"&FOO66" ForeColor —"833333" HorizontalAlign = 
"Center" / > 
<RowStyle BackColor ="FFFBD6" ForeColor ="833333" /> 
«SelectedRowStyle BackColor =" ЕО066" Font -Bold "True" ForeColor ="Navy" / > 
<SortedAscendinoCe11Style BackColor ="EDESAC" / > 
<SortednscendingHeaderStyle BackColor ="#D0000" / > 
«SortedDescendingCellStyle BackColor ="ECF6C0" / > 
«SortedDescendingHeaderStyle BackColor ="#20000" / > 
</asp:GridView > 
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查看 课程 CourseView. aspx. es 代码 如 下 : 


using System.Data; 
using System.Data.SglClient; 
pdolic partial class CourseView : System.Web.UI.Page 
{ 
protected void Page Ioed(doject sender, EventArgs e) 
{ 
if (!this.IsPostPack) 
{ 
string sql-"select * fram course"; 
["oonnstr"]; 
SqlConnection conn 2new SqlConnection (url) ; 
SqlCamand ard =new SqlCommand (sql, conn) ; 
SqlDataAdapter sda -new SqlDataAdapter (ато); 
DataSet ds -new DataSet () ; 
Sda.Fill (ds); 
this.GridViewl .DataScurce -ds. Tables [0] ; 
this.GridViewl .DataBird() ; 


} 
3. 教师 功能 
成 绩 管 理 界面 如 图 9-5 所 示 。 


En 


J D localhost2206/chap/D x V. 


€ > C |D localhost:2206/chap9/Default.aspx Y n" 


时 #it Google Chrome 浏览 器 保存 您 的 密码 吗 了 | РЕНА | | 此 网 站 一 香 不 保存 至 码 


成 绩 管理 
eres 学 号 ， [== 


ideis 课 号 ， [nise suami + 
D ] 
[sm] [вә] 


201403050001 = 1 数据 库 系统 原理 92 mk а 
201403050001 三 2 高 等 数学 78 mit 选择 
201403050001 =: 4 ВЕ o 选择 
201403050001 = т Bk 选择 
201403060002 ЛА 1 Bk 。 选择 
201403050002 Ax з Bü o 选择 
201403050002 WR 6 Bk o 选择 
201403050003 EL з 删除 o 选择 


图 9-5 成 绩 管理 界面 
成 绩 管理 ScoreManage. aspx 代码 如 下 : 


<asp:SqlDataSource ID -"SglDataScurcel" runat ="ѕегуег" 
ConnectionString -"Data Source =.;Initial Catalog =studentIb; Integrated 
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Security -True" 
ProviderName -"System.Data.SqlClient" SelectCcmmand —"SEIECT * FROM 
[course]" > 
</asp:SqlDataSourœ > 
«asp:SqlDataSource ID-"SqlDataSouroe2" ruat ="ѕегуег" 
GonnecticnString ="Data Source =.; Initial Catalog -studentTb; Integrated 
Security -True" 
ProviderName -"System.Data.SqlClient" SelectCcmmand —"SEIECT * FROM 
[student]" > 
«/asp:SqlDataSource > 
<br /> 
<asp:Iabel ID -"Tabell" runat ="server" Text =" > </asp:label1 > 
«asp:DrapDowrList ID —"dlSno" runat ="зегуег" DataSouroeID -"SdlDataSouroe2" 
DataTextField ="зпате" DataValueField ="sno" Width ="120px" > 
«/asp:DropDownList > 
<br /> 
«asp:label ID ="Tabe13" runat ="server" Text =" 课 号 "></asp:Iabel > 
«asp:DropDowrList. ID ="cdllCno" runat ="server" DataSouroeID -"SdlDataSourcel " 
DataTextField -"cname" DataValueField -"cno" Width ="120px" > 
«/asp:DropDownList > 
<br /> 
«asp:label ID -"Label2" runat -"server" Text = 成 绩 "></asp:Iabel > 
<asp:TextBox ID -"tbxScore" runat ="ѕегуег" > </asp:TextBox > 
<br /> 
«asp:Button ID -"Button]" гопа ="зегуег" onclick -"Buttonl Click" Text = 
"添加 " /> 
&nibsp; &nbsp; &nbsp; 
«asp:Butten ID -"Buttor?" rnat ="server" onclick =" Воо Click" Text =" / > 
<br /> 
«asp:Iabel ID-"]blMessage" runat ="server" style -"color:Fed;" > «/asp:label > 
<br /> 
<asp:GridView ID -"GridViewl" runat ="server" AutcGenerateColums -"False" 
GellPadding ="4" DataKeyNames -"sno, спо" ForeColor ="833333" 
GridLines -"None" onrowdeleting-"GridViewl RowDeleting" 
Width ="700рх" onselectedindexchanged -"Gridview| SelectedIndexhanged" > 
<AltematingRowStyle BackColor ="White" /> 
«Colums > 
«asp:BoundField DataField —"sno" Header Text 二 学 号 " /> 
«asp:BoundField DataField -"sname" HeaderText = 姓名 " /> 
«asp:BoundField DataField "ano" HeaderText 二 课 号 " /> 
«asp:BoundField DataField ="спате" HeaderText = 课程 名 " /> 
<asp:EBoundField DataField "soore" Header Text "RR" / > 
<asp:CamandField ShowDeleteButton -"True" /> 
<asp:CormandField ShowSelectButton "Træ" / > 
«/Oolums > 
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<FooterStyle BackColor —"890000" Font -Bold -"True" ForeColor —"White" /> 

«HeaderStyle BackColor —'890000" Font -Bold -"Tnue" ForeColor White" / > 

«PagerStyle BackColor ="EFOD66" ForeColor —"833333" HorizentalAlign = 

"Center" /> 

<RowStyle BackColor ="FFFBD6" ForeColor —'833333" /> 

<SelectedRowStyle BackColor —'£FOO66" Font -Bold ="True" ForeColor = 
"Navy" /> 

<SortedascendingcellStyle BackColor =" ТЕБАС" /> 

«SortedAscendingHeaderStyle BackColor ="#D0000" / > 

<SortedDesoendingCellStyle BackColor =" ФСРБО)" / > 

<SortedDescendingHeaqerStyle BackColor ="820000" / > 


</asp:GridView > 


成 绩 管理 ScoreManage. aspx. cs 代码 如 下 : 


using System.Data; 
using System.Data.SqlClient; 
public partial class ScoreManage : System.Web.UI.Page 


{ 


protected void Page Ioed(doject sender, EventArgs e) 


{ 


} 


if (!this.IsPostBack) 
{ 
this.BindaridViewData (); 


protected void Buttonl Click (doject sender, EventArgs e) 


{ 


string sno -this.ddlSno.Selectedvalue; 

string аю -this.ddlQno.Selectedvalue; 

string score —this.tbxScore.Text; 

string url -System.Configuration.ConfigurationManager .AppSettings 

["connstr"] ; 

SalConnection conn =new SqlConnection (url) ; 

сопп.Ореп () ; 
string sql ="insert into sc values (sno, (cro, @soore) "; 
SqlCoamand amd =пем SqlCamand (sql, conn) ; 
SqlParameter paramil ew Sql Parameter ("Gsno", sno); 
SqlParameter paran? ew Sql Parameter ("ёспо", cno) ; 
SqlParameter param ew Sql Parameter ("Gscore", score); 
amd. Parameters Acid (paranil ) ; 
ard. Parameters .Zcd (paran?) ; 
amd. Parameters .Pdd (paran) ; 


ad. ExecuteNorQuery () ; 
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) 


} 
catch (Exception excption) 
{ 
if ("УБА f PRIMARY KEY 约 束 ' 开 Sc' 不 能 在 对 象 'doo.sc' 中 插入 重复 键 。\r nn 语句 
已 终止 " ==exqption.Message) 


this.IblMessage Text. "该 学 号 和 课程 号 的 成 绩 已 经 存在 ,不 能 再 添加 "; 
retum; 


} 
finally 
{ 
conn.Close() ; 
] 
this.lblMessage Text "FRIR "; 
this.Bind3ridviewbata () ; 


private void BindaridviewData () 


{ 


) 


string sql ="ѕе]есі a.sno sno,a.sname sname,b.cno cno,b.cname cname, 
c.Soore score fran 

student a, course b,sc c where a.sno -c.sno and b.cno =с.аю"; 

string url -System.Configuration.ConfigurationManager .AppSettings 

["connstr"]; 

SalConnection conn =rew SqlConnection (url); 

Sqlcamand ard =new Sql Caand (sql, ccnn) ; 

SqlDataAdapter sda =new SqlDataAdepter (ата); 

DataSet ds =new DataSet () ; 

sda.Fill (ds); 

this.GridViewl .DataSource -ds.Tables [0]; 

this.GridViewl .DataBird() ; 


protected void Gridviewl RowDeleting (oject sender, GridViewDeleteEventArgs e) 


{ 


string sno -this.GridViewl .DataKeys [e.RowIndex] [0] .ToString () ; 

string mo this .GridViewl .DataKeys [e.RowIndex] [1] -ToString () ; 

string sql ="delete frm sc where sno -'" +зго+"' ard аю -'" 4ano +"""; 
["connstr"]; 

SqlConnecticn conn -new SqlOonnecticn (url) ; 

сопп.Ореп (); 

SqlCamand ard =пем SqlCamand (sql, оюп); 

amd. ExecuteNonQuery () ; 

com.Close() ; 

this.Bind3ridviewpata () ; 


) 


protected void Butto? Click (doject sender, EventArgs е) 


i 


} 


string sno -this.ddl8no.Selectedvalue; 

string cno -this.ddlQo.SelectedV/alue; 

string score -this.tbxScore. Text; 

string sql -"update sc set score =@score where sno sm and спо -( ano"; 
["connstr"]; 

SqlConnecticn conn =rew SqlConnection (url) ; 

conn.Open () ; 

SqlCamand ard -new SqlCcnmand (sql, conn) ; 

SalParameter param =пем SqlParameter ("Gsno", sno); 

SqlParameter paran? ew SqlParameter ("Gcno", аю); 

SqlParameter param -new Sql Parameter ("Gscore", score) ; 

ard. Parameters .Zctd (pararil ) ; 

ard. Parameters .Pdd (paran?) ; 

ard.Parameters.Acd (param) ; 

amd. ExecuteNorQuery () ; 

cmn.Close() ; 

this.lblMessage.Text = 路 改 成 功 "; 

this.BinderidViewData () ; 


protected void GridViewl SelectedIndexChanged (doject sender, EventArgs e) 


{ 


int index -this.GridViewl .SelectedIndex; 
string sno -this.GridViewl .Rows [index] .Cells [0] . Text; 
string ano -this.GridViewl .Rows [index] .Cells[2] . Text; 
string score -this.GridViewl .Rows [index] .Cells [4] .Text; 
foreach (ListItem item in this.ddlSno. Items) 
{ 

if (item.Value ==sno) 

{ 

this.ddlSno.SelectedIndex =this .ddlSno. Items. IndexOf (item) ; 


foreach (ListItem item in this.ddlCQno. Ttems) 
{ 
if (item.Value ==cro) 
this.ddlCno.SelectedIndex —this .ddlCno. Items. TndexOf (item) ; 


this.tbxSoore. Text -score; 
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查看 学 生 界 面 如 图 9-6 所 示 。 


所 > C [D localhost2206/chapS/DefaulLaspx _ 
早 it Google Chrome 浏览 可 保存 您 的 至 码 吗 》 [Gem] ita RR ER 


201403050001 


201403050002 bod 
201403050008 IFR 
201403050008 Sens 
201412030106 张无忌 


图 9-6 查看 学 生 界 面 


查看 学 生 StudentView. aspx 代码 如 下 : 


<asp:Gridiew ID -"GridViewl" runat -"server" AutcGenerateColums -"False" 


Cel 1Padding ="4" ForeColor —"833333" GridLines —"None" Width ="600px" > 

«AltematingFowStyle BackColor —"White" / > 

«Colums > 
«asp:BourdField DataField -"sno" HeaderText 二 学 号 " /> 
<asp:BoundField DataField ="sname" HeaderText "姓名" /> 
«asp:BoundField DataField -"ssex" HeaderText = 性 别 " /> 
«asp:BoundField DataField ="sage" HeaderText = 年 龄 " /> 
«asp:BoundField DataField "sdept" HeaderText "RHI" /> 

«/Oolums > 

<FooterStyle BackColor —*$90000" Font -Bold -"True" ForeColor -"White" /> 

«HeaderStyle BackColor ="990000" Font -Bold -"True" ForeColor -"White" /> 

«PagerStyle BackColor ="#ЕОС66" ForeColor ='"833333" HorizontalAlign = 

"Center" / > 

<RowStyle BackColor ="PFFFBD6" ForeColor ="833333" /> 

<SelectedRowStyle BackColor -"FKFOO66" Font -Bold ="True" ForeColor ="Navy" /> 

<SortednscendingCellStyle BackColor ="EDESAC" / > 

<SortedAscendircHeaderStyle BackColor ="#D0000" / > 

<SortedDescendingcellStyle BackColor ="ECF6C0" / > 

<SortedDescendingHeaderstyle BackColor —"820000" / > 


</asp:GridView > 


using System. Data; 
using System. Data.SqlClient; 
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public partial class StudentView : System.Web.UI. Page 
{ 
protected void Page Ioed(doject sender, EventArgs е) 
{ 
if (!this.IsPostPack) 
{ 
string sql-"select * fram student"; 
["connstr"]; 
SqlConnecticn conn =пем SqlConnection (url) ; 
SqlCamand amd =new SqlCamand (sql, ооп); 
SqlDataAdapter sda -new SqlDataAcapter (and) ; 
DataSet ds -new DataSet () ; 
sda.Fill (ds); 
this.GridViewl .DataScurce -ds. Tables [0] ; 
this.GridViewl .DataBird() ; 


) 


4. 管理 员 功 能 
学 生 管理 界面 如 图 9-7 所 示 。 


课程 管理 |8. ] 
用 户 管理 |а, ] 
[175 ] 
Fe | ] 
ЕЗ, ] 


性 别 Fe 


k; 
201403050001 = 


= 5 i ® 2% 
201403050002 WER ox 19 机 械 ne аң 
201403050003 XS k 18 计算 机 Юю as 
201403050008 张 立 志 5 19 生物 Bk а 
201412030106 张无忌 Ж a 土建 删除 x 


- 二 IE 
J D localhost2206/chapb/O x V x 
€ > C |D localhost:2206/chap9/Default.aspx i [1 三 
T it Google Chrome 浏览 器 保存 您 的 到 码 吗 ? 此 网 站 一 律 不 保存 至 码 


图 9-7 学生 管理 界面 


学 生 管理 StudentManage. aspx 代码 如 下 : 


<asp:Panel D="Panell" runat ="server" > 
<asp:Iabel ID -"Label1" runat ="server" Text ==" > </asp:label > 
<asp:TextBox ID-"tbxSno" runat ="зегуег" ></asp: TextBox > 
<br /> 
«asp:label ID -"Label2" runat -"server" Text =" 姓 名 " ></asp:Iabel > 
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X/asp:Panel > 


<asp:TextBox ID-"tbxSname" runat ="server" > </asp:TextBox > 

<br /> 

<asp:Iabel ID="Tabe13" runat 一 server" Text = ФЕ |" > «/asp:Tabel > 

<asp:TextBox ID -"tbxSsex" runat ="server" > </asp:TextBox > 

<br /> 

«asp:label ID -"Label4" runat -"server" Text =F" > «/asp:Label > 

<asp:TextBox ID -"tbxSage" runat "server" > «/asp:TextBox > 

<br /> 

«asp:label ID -"Label5" runat -"server" Text 一 系 别 "></asp:Iabel > 

<asp:TextBox ID —"toxSdept" runat "server" > </asp:TextBox > 

<br /> 

<asp:Button ID="Buttonl" runat ="server" Text ="П" cnclick= 
"Вла Click" /> 

&nibsp; &nbsp; abp; 

«asp:Button ID -"Buttan2" runat ="ѕегуег" Text = 路 改 " onclick= 
"Button? Click" /> 

dr /> 

«asp:label ID-"IblMessage" runat -"server" style ='oolor:Red;" > «/asp:label > 


Xasp:Panel ID ="Раге]2" runat ="ѕегуег" > 
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<asp:Parel ID ="Раге13" runat ="server" > 
<asp:SqlDataSourœ ID -"SqlDataScuroel" runat -"server" 
Cornnecticnstring=Data Source =.;Initial Catalog =sturEntIb;Integrated 
Security -True" 
ProviderName -"System. Data .SqlClient" 
lectCammnd ="ЅЕІЕСТ * FRM [student]" 
leteCamand ="ГЕТЕТЕ FRM [student] WHERE [sno] -esno" 
JnsertCamand -"INSERT IND [student] ([sno], [snae], [ssex], [sage], 
[sdept]) VALUES (sno, @зпате, @ѕзех, @ѕасе, Gsdept)" 
UpdateCamrend "PAIE [student] SET [snarre] -@sname, [ssex] =@зэзех, 
[sage] sage, [sdept] -Gsdept WHERE. [sno] =@зго" > 
«DeleteParameters > 
«asp:Parameter Name ="згю" Type -"String" / > 
«/DeleteParameters > 
XInsertParameters > 
«asp:Parameter Name -"sno" Type -"String" / > 
«asp:Parameter Name ="зпате" Type "String" / > 
«asp:Parameter Name -"ssex" Type 2"String" / > 
«asp:Parameter Name -"sage" Type ="Int32" /> 
«asp:Parameter Name ="sdept" Туре -"String" /> 
«/InsertParameters > 
XUpdateParameters > 
«asp:Parameter Name -"srame" Type -"String" / > 
«asp:Parameter Name ="ззех" Type -"String" /> 
«asp:Parameter Name -"sage" Type -"Int32" /> 


Sel 
Del 


<asp:Parameter Name —"sdept" Type "String" /> 
«asp:Parameter Name ="=по" Type "String" /> 
X/UpdateParameters > 
«/asp:SqlDataSource > 
«asp:GridView ID -"GridViewl" runat ="зегуег" AutcGenerateColums = 
"False" 
GellPadiding ="4" DataSouroeID -"SqlDataScurcel" ForeColor 833333" 
GridLines —"None" onselectedindexchanged -"GridViewl | 
SelectedIndexChanged"" 
Width ="600px" DataKeyNames ="зго" > 
<AltematingRowStyle BackColor "White" /> 
«Colums > 
<asp:BoundField DataField ="sno" HeaderText 二 学 号 " 
SortFxpression ="sno" /> 
<asp:BoundField DataField "sname" HeaderText "姓名 " 
SortExpression -"sname" / > 
«asp:BoundField DataField ="ssex" Header Text: = 性 别 " 
SortExpression -"ssex" /> 
«asp:BoundField DataField "sage" HeaderText = 年 龄 " 
SortExpression-"sage" /> 
«asp:BouncField DataField -"sdept" Header Text =" HI)" 
SortExpressicn -"sdept" / > 
«asp:CamandField ShowDeleteButton -"True" / > 
«asp:CamendField ShowSelectButton "True" / > 
«/Colums > 
«FooterStyle BackColor ="#90000" Font -Bold-"True" ForeColor = 
"White" /> 
XHeaderStyle BackColor ="90000" Font -Bold "True" ForeColor = 
"White" /> 
XPagerStyle BackColor ="FFOC66" ForeColor —'$833333" 
HorizontalAlign —"Center" /> 
<RowStyle BackColor ="FFFBD6" ForeColor ='833333" / > 
«SelectedRowStyle BackColor =" ФЕОО66" Font -Bold "True" ForeColor = 
"Navy" /> 
<Sortednscendingcellstyle BackColor ="#ТЕ5АС" / > 
«SortedAscendingHeaderStyle BackColor ="#D0000" / > 
<SortedDescendingcellstyle BackColor ="gCF6C0" / > 
«SortedDescendingHeaderStyle BackColor ="#20000" / > 
</asp:GridView > 
«/asp:Panel > 
</азр:Раге1 > 


using System.Data; 
using System.Data.SglClient; 
public partial class StudentManage : System.Web.UI. Page 
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protected void Buttonl Click(doject sender, EventArgs е) 
t 

string sno -this.tbxSno. Text; 

string sae -this.tkxSname Text; 

string ssex -this.tbxSsex. Text; 

string sage -this.tkxSage. Text; 

string sdept -this.tkxSdept . Text; 

string url 4 Gafi io ° ç 

["соппзїг"]; 

SqlConnecticn conn =rew SqlConnecticn (url) ; 

conn.Open () ; 

String sql ='insert into student. values (@sno, @snane, @ssex, @sage, @sdept) "; 
SqlCamand ard =new SqlCamrand (sql, conn) ; 
SalParameter param =пем SqlParameter ("Gsno", sno); 
Sql Parameter paran? ew Sql Parameter ("Gsname", snare); 
SqlParameter param -new Sql Parameter ("@ззех", ssex); 
SqlParameter param ew Sql Parameter ("Gsage", sage); 
Sal Parameter рагапБ =new Sql Parameter ("@sdept", здері); 


if ("5 Y PRIMARY KEY Z]9 "ВК student'。 不 能 在 对 象 'doo.student' 中 插入 重复 键 。\ 
rn 语句 已 终止 " ==excpticn.Messace) 


this.lblMessage.Text "该 学 号 已 经 存在 ,不 能 再 添加 "; 
retum; 


) 
finally 
{ 
сопп.С1озе(); 
} 
this.lblMessage.Text "添加 成 功 "; 
this.GridViewl .DataBind() ; 
} 
protected void GridView] SelectedIndexChanged (Gbject sender, EventArgs е) 
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} 


string sno -this.GridViewl .Rows [index] .Cells [0] Text; 
string sname —this.GridViewl .Rows [index] .Се115 [1] Техі; 
if (=папе --"&nbsp;") 


string ssex -this.GridViewl .Rows [index] .Cells [2] .Text; 
if (ssx --"&nbsp;") 
t 
ssx ="; 
} 
string sage =this.GridViewl .Rows [index] .Cells [3] .Text; 
string scept -this.Gridviewl .Rows [index] -Cells [4] .Text; 
if (sdept --"&nbsp;") 
{ 
sept ="; 
) 
this.tbxSno. Text -sno.Trim() ; 
this.tbxSname.Text -sname.Trim() ; 
this.tbxSsex.Text -ssex.Trim() ; 
this.tbxSage.Text -sage.Trim() ; 
this.tbxSdept. Text -sdept..Trim() ; 


protected void Buttor2 Click (doject sender, EventArgs e) 


{ 


string sno =this.thbxSno.Text; 

string sname —this.tbxSname. Text; 

string ssex -this.tbxSsex.Text; 

string sage —this.tbxSage.Text; 

string sdept -this.tbxSdept Text; 

string url -System.Configuration.ConfiguratiorManager .AppSettings 
["connstr"]; 

SqlConnecticn conn -new SqlConnecticn (url); 

сопп.Ореп () ; 

string sql -"update student set sname =-@sname, ssex =@ззех, sage -6 sage, 
sdept -sdept 

where sno =@5п0"; 

SqlCamand ard =new SqlCamand (sql, оюп); 

Sql Parameter param =гем SqlParameter ("Gsno", sno); 

SqlParameter param? -new SqlParameter ("Gsname", snare); 

ЅоПРагапебег param -new Sql Parameter ("@5зех", ssex); 

Sal Parameter parah =гєм SqlParameter ("8sage", sage); 

SqlParameter paramb ew Sql Parameter ("Gsdept", збері); 
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课程 


ard. Parameters Ad (paranil ) ; 

arm. Parameters .ndd (paran?) ; 

amd. Parameters ct (paran3) ; 

ard. Parameters Add (param) ; 

amd. Parameters 7c (paranb) ; 

ard. ExecuteNorQuery () ; 
con.Close() ; 

this.lblMessage.Text =" 路 改 成 功 "; 
this.GridViewl .DataBind() ; 


管理 界面 如 图 9-8 所 示 。 


€ > С [D localhost2206/chap9/Default.aspx т = 


早 її Google Chrome 浏览 器 保存 您 的 至 码 吗 ? 


学 生 管理 


МЕЕ | samana nan 


课程 


«asp: 
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图 9-8 课程 管理 界面 


管理 CourseManage. aspx 代码 如 下 : 


GridView ID-"GridViewl" runat -"server" AutcGenerateColums -"False" 
Cell Padding ="4" ForeColor ="833333" GridLines —"None" Width ="500рх" > 
«AltematingRowStyle BackColor White" / > 
«Colums > 
«asp:BoundField DataField "no" HeaderText =" Еу" /> 
<asp:BoundField DataField ="спапе" HeaderText "课程 名 " /> 
<asp:BoundField DataField "qono" HeaderText = 前 导 课 课 号 " /> 
«asp:BoundField DataField "ocredit" HeaderText 二 学 分 " /> 
«/Colums > 
<FooterStyle BackColor ="B90000" Font -Bold ="True" ForeColor —"White" /> 
<HeagerStyle BackColor ="990000" Font -Bold -"True" ForeColor "ihite" /> 
«PagerStyle BackColor ="#ЕОС66" ForeColor —"833333" HorizontalAlign = 
"Center" /> 
«RovStyle BackColor ="FFFBD6" ForeColor ="833333" / > 
<SelectedRosStyle BackColor =" 0066" Font -Bold "True" ForeColor ="Navy" /> 


«SortedhscendingoellStyle BackColor ="EDESAC" / > 

«SortedAscendingHeaderStyle BackColor ="#D0000" / > 

<Sortedpescendingcellstyle BackColor ="#СЕ6ОО" / > 

«SortedDescendingHeaderStyle BackColor ="#20000" / > 
</asp:GridView > 


用 户 管理 界面 如 图 9-9 所 示 。 


€ > C [D localhost:2206/chap9/Default.aspx - 


早 it Google Chrome 浏览 各 保存 侈 的 至 码 吗 2 [eere | 此 网 站 一 健 不 保存 至 码 | * 


用 户 管理 


用 户 名 


laoshi laoshi 教师 EL mit 
admin admin жил ET Lis 
201403050001 1 学 生 ii miit 


图 9-9 用户 管理 界面 


用 户 管理 UserManage. aspx 代码 如 下 : 


<asp:Label ID ="Labe14" runat ="server" 
Text =" 注 意 : 学 生 用 户 的 用 户 名 只 能 是 学 生 表 中 存在 的 学 号 "> 

</asp:labe1 > 
<br /> 
<asp:Iabel ID-"Labell" runat -"server" Text -"JH] P! 4&4 : "></asp:Iabel > 
<asp:TextBox ID —"tbüserCode" runat ="ѕегуег" > «/asp:TextBox > 
<br /> 
«asp:label ID=Tabel2" runat ="зегуег" Text =": "></asp:Iabel > 
<asp:TextBox ID —tbxPassword" runat -"server" TextMode ="Password" > </asp:TextBcx > 
<br /> 
<asp:Label ID —"Label3" runat ="server" Text -"ffl ff, : "></asp:Iabel > 
«asp:DragDowrlist ID —"ddlFoleAcH" runat -"server" > 

<asp:ListItem Value ="1" >° #E «/asp:listItem» 

«asp:lástItem Value ="2" > 老师 «/asp:ListItem» 

«asp:ListItem Value ="3" > 管理 员 «/asp:ListItem? 
«/asp:Dropbownlist > 
<br /> 
«asp:Button ID=—"Butten1" runat "server" anclick=Buttonl Click" Text "RIM" /> 
<br /> 
«asp:label ID -"]blMessage" гопа -"server" > </asp:label > 
<br /> 
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«asp:GridView ID -"GridViewl" runat ="зегуег" AllowPaging —"True" 


AllowSorting -"True" AutcGenerateColums "False" CellPadding ="4" 
ForeColor ="33333" GridLines —"None" Width -"800px" 
onrowdatabound -"Gridviewl RowDataBound" 
DataKeyNames ="id" onrowcanoelingedit -"GridViewl RowCancelingEdit" 
cnrowdeleting -"Gridviewl RowDeleting" onrowediting ="GridViewl RowEditing" 
onrowupdating -"GridViewl RoWupdating" > 
<RlternatingRowStyle BackColor —White" /> 
«Colums > 
«asp:BoundField DataField "userCode" HeaderText "H P! 4 " /> 
«asp:BourdField DataField -"password" HeaderText = 密码 " /> 
<asp:TenplateField HeaderText "角色 "> 
<Ttenterplate > 
<asp:lebe1 ID -"IblFole" nmt "server" Text =' «val ("role") >' > 
«/asp:label > 
«/Ttenflenplate > 
«EditItenflenplate > 
«asp:DrapDownList ID -"dlFole" runat -"server" Width -"151px" > 
«/asp:DropDownList > 
«/EditItenilemplate > 
«/asp:TenplateField > 
«asp:Camandrield ShowEditButton -"True" / > 
«asp:CamandField ShowDeleteButten "True" /> 
</Colums > 
<FooterStyle BackColor ="#90000" Font -Bold ="True" ForeColor -"White" /> 
<HeaderStyle BackColor ="990000" Font -Bold "True" ForeColor White" /> 
XPagerStyle BackColor ="FFOC66" ForeColor ='B33333" HorizontalAlign = 
"Center" /> 
<RowStyle BackColor —"£FFBD6" ForeColor ="833333" / > 
«SelectedRowStyle BackColor ="fF0%66" Font -Bold -"True" ForeColor ="Navy" / > 
«SortedAscendingoellStyle BackColor ="FDF5AC" / > 
«SortedAscendingHeaderStyle BackColor ="#D0000" / > 
<SortedDescendingCellStyle BackColor ="FCF6CD" / > 
<SortedDescerrlingHeaderStyle BackColor —"820000" / > 


</asp:GridView > 


using System.Data; 
using System.Data.SqlClient; 
public partial class UserManage : System.Web.UI.Page 


{ 
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protected void Page Ioed(doject sender, EventArgs e) 


if (!this.IsPostBack) 
t 
this.Bindaridview() ; 


) 


protected void Gridviewl RowDataBound (dbject sender, GridViewEowEventArgs e) 


t 


if (e.Row.Rowlype —-DataControlRowlype.DataRow) { 
if (e.Row.RowState = -DataControlRowState.Nommal 
|| e.Row.RowState —-ataControlRowState.Alterate) 


Iabel 1blRole -e.Row.FindOontrol ("JblRole") as Label; 
if (IblFole ! -null) 


{ 


if (IblFole.Text =="1") 


{ 


lblFole.Text = 学 生 "; 


else if (lblRole.Text =="2") 


t 


) 


lblFole.Text =" ili"; 


else if (IblFole.Text =="3") 


{ 


lblRole.Text = 管理 员 " 


if ((e.Row.RowState & DataControlRowState.Edit) == 
DataControlFowState.Fdit) 


DropDowrList ddlFole -e.Row.FindOontrol ("ddlFole") as 


DropDownList; 


if (ddlRole ! -null) 


{ 


listItem item -new ListItem(); 
iteml.Value ="1"; 

ital. Tet =E"; 
ddlFole.Itms.Ad (ital); 
ListItem iten? =new ListItem(); 
iten?.Value ="2"; 

iten? Text "HUM"; 
ddlFole.Items.A2cd (item?) ; 
ListItem itend -new ListItem(); 
itenB.Value ="3"; 

itenB Text =Ë J fi w; 
ddlFole.Items.2cd (item) ; 
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protected void GridViewl RowEditing(doject sender, GridViewEditEventArgs e) 
{ 
this.GridViewl .EditIndex -e.NewEditIndex; 
this.BindGridView() ; 
} 
protected void Gridviewl RowUpdating (cbject sender, GridViewUpdateFventAros e) 
{ 
int index -e.FowIndex; 
string role -( (DraggDownList) this .GridViewl .Rows [index] .Findcontrol 
("GdlRole") ) .Selectedvalue; 
string userCode =( (TextBox) this.GridViewl .Rows [index] .Cells[0]. 
Controls[0]) .Text; 
string password =( (TextBox) this.GridViewl .Rows [index] .Cells[1]. 
Controls[0]) .Text; 
string id =this.GridViewl .DataKeys [index] [0] .ToString(); 
string sql "update [user] set userCode -GuserCode, password =@password, 
role =@role where id-Qid"; 
string url -System.Configuration.ConfigurationManager .AppSettings 
["connstr"] ; 
SalConnection conn new SqlConnection (url) ; 
conn.Open  ; 
SqlCamand amd =пем SqlCamand (sql, conn) ; 
SqlParameter paraml =new Sql Parameter ("&userCode", userCode) ; 
SqlParameter paran? ew Sql Parameter ("&password", password) ; 
SalParameter param -new Sql Parameter ("Grole", role); 
SqlParameter param new SqlParameter ("@id", id); 
and. Parameters .Dod (parami) ; 
and. Parameters Aci (paran?) ; 
ard. Parameters .Add (param) ; 
amd. Parameters Aci (parah) ; 
amd.ExecuteNorQuery () ; 
сопп.С1озе(); 
this.GridViewl .EditIndex = 1; 
this.Bind3ridview() ; 


} 
protected void Gridviewl RowCancelingedit (doject sender, 
GridViewCancelEditEventArgs e) 


this.Gridviewl .FditIndex =-1; 
this.Bindaridview() ; 
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private void Bindridview() 


{ 


) 


string sql-"select * fram [user]"; 
["connstr"]; 

SqlOonnecticn conn =new SqlOonnecticn (url) ; 

сопп.Ореп (); 

SqlCamand ard =new SqlCcrmand (sql, oonn) ; 

SqlDataAdapter sda -new SqlDataAdapter (ато); 

DataSet ds -new DataSet () ; 

Sda.Fill (ds); 

this.GridViewl .DataSouroe -ds. Tables [0]; 

this.GridViewl .DataBird() ; 

conn.Close() ; 


protected void Buttonl Click (doject sender, EventArgs e) 


{ 


) 


string role =this.ddlRolexdHd.SelectecValue; 

string userCode -this. tbxUserCode Text; 

string password -this. tbxPassword. Text; 

string sql -"insert into [user] values (@userCode, épassword, гое)"; 

string url -System.Configuration.ConfigurationManager .AgoSettings 
["connstr"]; 

SqlConnecticn conn =new SqlConnection (url) ; 

conn.Open () ; 

Sal Oanmand ard new SqlCcrmand (sql, conn) ; 

SqlParameter paraml =new Sql Parameter ("&userCode", userCode) ; 

SqlParameter paran? ew Sql Parameter ("&password", password) ; 

SqlParameter param ew Sql Parameter ("@role", role); 

and. Parameters Aci (param ) ; 

ard.Parareters Aci (paran?) ; 

ard. Parameters .Acd (param) ; 

amd.ExecuteNorQuery () ; 

con.Close() ; 

this.Bind3ridview() ; 


protected void Gridviewl RowWDeleting (oject sender, GridviewDeleteFventArgs е) 


ji 


string id-this.GridViewl .DataKeys [index] [0] .ToString () ; 

string sql -"delete frm [user] where 14=@14"; 
["connstr"]; 

SqlConnecticn conn =rew SqlConnecticn (url) ; 

conn.Open () ; 
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SqlCamand ard =new SqlCormand (sql, oonn) ; 
SqlParameter param new SqlParameter ("Qid", id); 
ard. Parameters Ad (param) ; 


arxd.ExecuteNorQuery () ; 
omn.Close() ; 
this.Bind3ridview() ; 


四 、 项 目 小 结 


本 项 目 展示 了 项 目 开发 全 过 程 ,在 学 完 本 项 目 后 ,学 生 遇 到 实际 问题 ,就 知道 该 如 何 进 
行 开发 ,而 不 会 再 出 现 不 知道 从 哪里 下 手 这 样 的 问题 。 
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